This article has participated in the activity of “New person creation Ceremony”, and started the road of digging gold creation together.
When reviewing a student’s technical solution this week, I found that after the technical solution was launched, the team members needed to change their existing r&d habits, which was not recognized by most developers of iOS platform. The feedback at that time was that it was not recommended to implement it, and it did bring some benefits of reducing the amount of code. But there are risks in terms of the long-term maintenance costs of the team and the understanding of the newcomers. Then I took this opportunity to sort out my understanding of the relationship between the scheme and the platform ecology, so as to avoid stepping on the same pit. Please do not ask me about the detailed background, and I will not tell you.
In the process of research and development, in order to research and development of convenience, to encapsulate a series of functions, including the system encapsulate some native API, design and implement a series of components support reuse, so after using encapsulation component, the complexity of the code, will be reduced, indirect and improve the efficiency of research and development. This way is the norm in the process of research and development, effective and reuse was the key to development goals, but for the design and realization of the basic tools/components should avoid excessive design, also need to balance the benefits and complexity, as much as possible with the platform of the design, implementation, and the use of the ecological idea is consistent, it need to pay attention to the following summary.
- Habits: it refers to the common coding habits of most of the developers in this platform and ecosystem. If most of the students in the team have bad coding habits, this should be solved through coding specifications. When a module (component) defines a separate standard, which conflicts with the current coding convention, or double standard. This is very easy because of the coding habits of research and development personnel, not specifically for this module (component) adaptation, and lead to unexpected exceptions (this problem is difficult to locate, habits have not been turned over, the idea has not changed).
- Norms: There are mainly two kinds of norms, ecological norms and team norms;
-
- (3) Ecological specifications: refers to the overall ecological specifications of the development platform, including the use of the development language and the product production process. For example, the iOS platform is not allowed to use self-construction browsing (struck), so there is no need to do this; The iOS platform does not allow the use of non-public apis, so this use is risky.
- Team specification: Generally assets is accumulated research and development team, some experience from the pit, common such as coding standards, process specification, when the use of components designed has conflict with these specifications, is actually in establishing the new specification, or a special case of the specification, there should be a mechanism to ensure no person, again after a period of time it will need to archaeology, maintenance costs will increase. If you are interested in my understanding of specifications, the value of specifications in research and development
- Base point: base point refers to the origin of the basic ability necessary for platform developers, which determines the cost of daily technical communication and understanding in the team. Generally speaking, simplicity is also one of the goals of module design. What is simplicity? For a given platform, the complexity of the technology used in the components, or the degree of technical mastery, is in line with the basic technical points that are expected to be mastered by industry standards and can be quickly understood by most developers. For some dark magic, the utility of high level persistence should be locally effective and information hidden, otherwise the cost of long-term maintenance and repair of exceptions will increase.
- Balance: every design has its thinking logic behind it, and it can solve the problem and get the benefit. The effect actually remains until the module goes offline. Directly speaking, we should look at both short-term and long-term effects. Look at the impact on the project as well as the team. When there is a conflict between project goals and team goals, the team should come first in the long run. When there is a conflict between team and ecology, ecology should be given priority and ecology, team and project should be balanced. The product survives first, then the rationality of the architecture, and then the concrete project landing, and the reverse is what the disrupter should do.
Other reference
- [Thinking about the process of architecture Optimization] Quality over efficiency
- Avoid random trial and error
- [Thinking on the process of architecture optimization] Continuous technological innovation
- [Thinking about the process of architecture Optimization] the value of specifications in R&D work
- Summary of componentization benefits of R&D process
- [Thinking about the process of architecture optimization] It is better to determine things by people than by people
- Five key points of CR
- Three dimensions of technical solution evaluation
- The meaning of communication
- [Thinking on the process of architecture optimization] Platform ecology is given priority
- [Thinking on the process of architecture optimization] The sorting principle of technical requirements