Through the work in the problem definition and conclusion model stage, we have analyzed and defined various models related to the system development goals, analyzed the system function list, performance requirements and so on, and explained the problem of “what is the system goal”. In the system planning stage, the main work to be completed is to explain “how the system is implemented”.
The main content of system programming includes the following aspects.
1 Determine the software architecture
The software conceptual model obtained during the problem definition phase defines the development goals of the project using various tools. It’s during the system design phase that you really start thinking about how to implement the software. One of the most important work, is to develop the implementation of the system architecture.
The implementation architecture of the system is related to some very specific aspects:
(1) Analyze the structure of the model
For example, the use of structured analysis methods to obtain functional decomposition systems, or object-oriented classes and “object-relational diagrams”, “object-behavior diagrams”.
(2) some of the most basic and important implementation elements corresponding to the system goals
For example, key use cases, the most important control classes, patterns of object organization, common and most critical implementation algorithm models, etc. These realization elements correspond to the most important scenes of system goal realization and represent the most important control flow and realization mechanism of the whole system.
(3) Explanation of features and key points
These additions explain how some of the system’s features, services, and so on are implemented.
2 Key elements and means of implementation
Key implementation elements usually include:
- Key use cases, primary control classes, primary organization of functions and services (for example, the home page of a website);
- Object organization mode;
- Commonly used and most critical implementation algorithm models.
Key means of implementation usually include:
- Select basic computing platform, such as operating system, database, Web server, middleware platform, etc.
- Select development tools and development environments, such as computer languages, component libraries, tool software, etc.
3. Boil down the goals to the most appropriate computing system
Often, organizations providing development tools and environments have some standard computing systems to choose from (for example,.NET, J2EE, etc.), so for most systems development projects, the computing system can be selected by comparing the matching of various standard computing systems with the desired goals. The choice of standard computing system to implement the system can ignore most of the basic platform and the implementation of the underlying support technology, so as to greatly improve the quality of the system, reduce development risk and cost.
Developers often choose the system implementation technology system according to the system implementation capability support of the base platform, the technology accumulation of the company or the project team on the specific implementation platform, and even the “advanced” or popularity of the technology.
In other cases, the underlying platform of the system may well have been determined during the demonstration phase of the project due to factors such as user investment, consistency, compatibility, scalability, and future maintenance with the user’s existing IT infrastructure. Such as operating system, database system, Web server, development tools or development environment, etc. In this case, the implementation architecture of the system is actually determined.
By reference system concept model at the same time, will get in front of the list of system function and system implementation of various key elements arrangement and classification, and then with the existing technology, the realization of the standard system, comparison and matching can be defined system conceptual model of the system target, can further mapped to real calculation, system architecture.
This process can be understood as a constant process of summarizing, comparing and matching. The matching process is often a two-way selection and exploration process. On the one hand, take out the functions or implementation elements in a system goal and ask: does this part of the function belong to the presentation layer, business logic, or data service? On the other hand, we also examine the capabilities provided by standard computing systems, such as: is it appropriate to place them in the business logic layer? Does the technician have experience in this area? Are even standard artifacts or services available?
Standard computing systems can be complex, but usually include some logical division. For example, THE.NET architecture understands the application system as consisting of three layers: the presentation layer, the transaction logic layer, and the data services layer.
(1) Presentation layer
The user interface part. Examples include single-application user interfaces, C/S computing mode clients, B/S mode running HTML, DHTML, Scripting, JavaApplet, ActiveX, etc.
(2) Transaction logic layer
Be responsible for processing application request of presentation layer, complete computation task of business logic, and return processing result to user. The transaction logic processing layer separates the transaction logic originally placed in the client side and centralizes it in the server part, which is shared by all users. The transaction logic layer is the core of the application, and the component object model COM is its heart. The Transaction logic layer handles transactions through COM, and is composed of IIS (Internet Information Server) and MTS (Microsoft Transaction Server). Microsoft Transaction Server) provides complete management for various application components.
(3) Data service layer
Provide data sources for applications. Different from the previous two-tier architecture, the database no longer maintains a connection with each active customer, but several customers share the connection of the database through application logic components, thus reducing the number of connections and improving the performance and security of the data server.
The same three-tier computing pattern will also show different implementations. For example, the presentation layer might be a user interface for a single application, a client for C/S computing, or Web pages and elements for B/S computing; The transaction logic layer may be a program module of a single application system, a server service of C/S, a business script or a business object in a B/S application server. When data manipulation logic is implemented using similar stored procedures, stored procedures are also considered as part of the transaction logic layer, but when data access components such as ADO (ActiveX DataObject) are used to access data, ADO and background database system and database logic is regarded as a part of the data service layer.
Where necessary, a hierarchy can be further subdivided. For example, systems using object-oriented design methods often divide the transaction logic layer into basic computational objects, business objects, and script “glue” or control classes that bind the business object implementation functions.
When the system realization elements are summed up into the computing system, the key point is to understand the general stratification and composition of various computing systems, and compare the “suitability degree” between the goals of the realization elements and the means of realization, rather than mechanically copying a certain realization mechanism, or blindly pursuing a “popular” or “advanced” computing system.
After the system scheme is formulated, it needs to be evaluated according to relevant standards to find out the inconsistencies and then make improvements.