Basic qualities of programmers:
To be a truly qualified programmer, or a programmer who can be truly qualified to complete some code work
should have quality.
1: Team spirit and collaboration ability
Regarding it as a basic quality is not unimportant, on the contrary, it is the most basic thing that programmers should have,
It is also the most important foundation for settling down and establishing a life. Anyone who calls high-level programmers loners is nonsense. The power of any individual is limited. Even a genius like Linus needs to be formed through
A strong team can create miracles. It is unimaginable without the spirit of collaboration among experts who write cores for Linux all over the world.
Lone Ranger can make some money-making small software and make a little fortune, but once he enters the R&D team of some large systems and enters the commercialization and product development tasks, he lacks
People of this caliber are completely unqualified.
2: Documentation habits
Anyone who says that high-level programmers never write documents is definitely a naive child. Good documentation is very important in the formal research and development process
The important link is that as a code programmer, it is normal to spend 30% of the working time writing technical documents. As a senior programmer and system analyst, this ratio is much higher. Without
documentation, a software system lacks vitality and will encounter great trouble
in future troubleshooting, upgrades, and module reuse.
3: Standardization, standardized code writing habits
As the rules of some well-known foreign software companies, the variable naming of the code, the comment format within the code, and even nesting
The length of the indentation of the middle line and the number of blank lines between functions are clearly defined. Good writing habits will not only help the transplantation and error correction of the code
, but also help the communication between different technical personnel. collaboration. Fans
s clamor that the code written by high-level programmers is never understood by others. This clamor only proves that they themselves are not worthy of calling themselves programmers.
The code has good readability, which is a basic quality requirement for programmers. Looking at the entire Linux construction,
Without standardized and standardized coding habits, global R&D
collaboration is absolutely unimaginable.
4: Requirement understanding ability
Programmers need to understand the requirements of a module. Many children often only focus on one functional requirement when writing programs. They
put performance All indicators are attributed to the hardware, operating system and development environment, and the performance considerations of the own code are ignored
Someone once said that writing an advertising exchange program is easy, such people never
I don’t know how to achieve performance indicators in the case of millions or even tens of millions of accesses. For such a programmer, even if you give him Deep Blue’s system, he won’t be able to do it. The ability to access the Tai Chi chain. Among the performance requirements indicators, stability
, parallel access support capabilities and security are all important. As a programmer, you need to
evaluate the environment in which the module operates during system operation. The load pressure and the possibility of various potential dangers and malicious
attacks. In this regard, a mature programmer needs at least 2 to 3 years of project development and tracking experience to be able to gain experience.
5: Reusability, modular thinking ability
It is often heard that some programmers have such complaints. After writing programs for several years, they have become skilled workers and work hard every day. Yes
Repeatedly writing code without any new ideas is actually the biggest waste of Chinese software talents. Some repetitive work
has become the main job of skilled programmers, and These are actually completely avoidable
.
Reusability design and modular thinking require programmers to think more
when completing any functional module or function, and not be limited to completing the current task. In terms of ideas, think about whether the module can exist outside of this system
and whether it can be directly referenced in other systems and application environments by simply modifying parameters. In this way
This can greatly avoid repetitive development work. If a software development unit and working group can consider these issues in every development process, then programmers will not be involved in repetitive development work. If you waste too much time at work, you will have more time and energy to devote to innovative code work.
Some good program module codes, even if they were written in the 1970s, can be used very well as functional modules in some systems.
Now I What we have seen is that many small companies often rewrite the entire code as soon as their software is upgraded or improved, and most of the repetitive work is a needless waste of time and energy.
6: Testing habits
As for some commercial and formal development, full-time test engineers are indispensable, but it does not mean that
there are Programmers do not need to conduct self-tests if they have full-time test engineers; as a project, software development has a very important feature: the earlier the problem is discovered, the lower the cost of solving it.
By carefully testing each piece of code and each sub-module after completion, some potential problems can be discovered and solved as early as possible
so as to improve the overall system construction. Efficiency and reliability are guaranteed.
Testing work actually needs to consider two aspects. On the one hand, it is the test of normal calls, that is, to see whether the program can
complete basic functions under normal calls. This is the most basic. Testing responsibilities, unfortunately in many companies, this has become the only testing task
In fact, it is far from that; the second aspect is the testing of abnormal calls, such as stability under high pressure loads
Performance testing, testing in the case of potential abnormal input from users, testing of the impact of the module in the case of partial failure of the overall system
Module stability when frequent abnormal requests block resources Testing and more. Of course, programmers do not need to conduct such complete testing on every piece of their own code, but programmers must clearly understand that their code tasks are in the overall project. status and various performance requirements, conduct relevant tests in a targeted manner, and discover and solve problems as early as possible. Of course, this requires the above-mentioned requirement understanding capabilities.
7: The ability to learn and summarize
Programmers are a profession where talents can easily be eliminated and fall behind, because a technology may only be available in three or two years
With leading edge, if programmers want to make a living, they must constantly follow up on new technologies and learn new skills.
Being good at learning is a necessary motivation for advancement in any profession. For programmers, this requirement is even higher
But you also need to find the right target for learning. Some small coding and some codingTO are just like this. There are only some Cfans in coding. They also talk about their learning ability. They learned ASP in one moment, and learned ASP in the next. After learning ph
p, they learned jsp in a while. They use this as a way to show off, blindly chasing some superficial and superficial things
and nouns, and they don’t understand network programming. Communication transmission protocols and application programs do not understand interrupt vector processing. Such technical personnel will never make qualitative improvements no matter how many so-called new languages ??they master.
Being good at summarizing is also a manifestation of learning ability. Every time you complete a research and development task or a piece of code, you should purposefully track the application status and user feedback of the program. , summarize at any time, find your own shortcomings, and gradually improve in this way, a programmer can grow up.
Even if a programmer who does not have growth potential appears to be a master at first sight, it is recommended not to choose him, because the time will come when he will fall behind.
People who have all the above qualities should be said to be qualified programmers. Please note that the above qualities are not determined by IQ, nor can they be learned in some college textbooks. They need to It's just the programmer's understanding of his or her work, and it's a matter of consciousness.
As a senior programmer, or even a system analyst, that is, a designer of a program project
In addition to possessing all the above-mentioned qualities, you also need to possess The following qualities:
First, requirements analysis ability
For programmers, understanding the requirements can complete qualified code, but for the organization and management of R&D projects
Managers, they not only have to understand customer needs, but more often they also have to formulate some of their own needs. Why do you say that?
Generally speaking, when conducting R&D tasks, it may be the needs put forward by customers, or the needs put forward by the marketing and marketing departments. At this time, for the R&D department, what they see is not A complete requirement. Generally speaking, this requirement is just some functional requirements, or more formally, it is possible to obtain a complete user view; but this is not enough, because
Because there are more non-technical factors for customers, it may be difficult for them to put forward complete and clear, or professional performance requirements
But for project organizers and planners, they must be able to clearly understand Be aware of the existence of these requirements and put them forward appropriately when completing the requirements analysis report. At the same time, they must be completely and clearly reflected in the design instructions to facilitate coding by programmers. These principles will not be lost.
Programmers must correctly understand the environment in which user needs are located, and make targeted analysis of the needs. For example,
for example, the same software is released and passed through ASP rental. Released under License, the performance requirements may be different
. The former emphasizes better support capabilities and stability, while the latter may emphasize more on various platforms
Universality and simplicity of installation and use.
Second, project design methods and process processing capabilities
Programmers must be able to master no less than two to three project design methods (such as top-down design methods)
Methods, such as rapid prototyping methods, etc.), and be able to select appropriate design methods according to project needs and resource allocation for
the overall design of the project. Improper selection of design methods will delay the R&D cycle, waste R&D resources, and even affect R&D results.
A programmer also needs to spend a lot of time on the design and processing of flow charts. He needs to make data flow diagrams
to establish a data dictionary; he needs to process logical flow diagrams. To form an overall system processing flow. A system with process problems
no matter how beautiful the code is and how exquisite each module is, it will not become a good system. Of course, doing a good job of process
analysis and choosing a good project design method requires a sufficient grasp of demand analysis capabilities.
Third, reuse design and modular decomposition capabilities
This seems to be an old tune again. Didn’t the basic qualities already explain this issue before? As a programmer engaged in module tasks, he needs to consider the reusability of the specific functional modules he faces. As a system analyst, he The problems to be faced are much more complex, and the overall system needs to be decomposed into many reusable functional modules and functions according to a modular analysis capability, and an independent system must be formed for each module. design requirements.
For example, take car production. At first, each car was installed independently, and each component was tailor-made.
But it changed later. Machines With mass production, a car factory began to produce cars through assembly lines, and independent parts
began to have a certain degree of reusability. Later, standardization became a major trend, with different models, brands and even different manufacturers
p>
Automotive parts can also be easily replaced and upgraded. At this time, the efficiency of automobile production is maximized.
The same is true for software engineering. In a mature software industry, in some related projects and systems, different
components can be replaced at will, such as many Microsoft desktops. Software, in many operation modules (such as opening files,
saving files, etc.), the same set of functional modules are reused, and these interfaces are provided to
through some class libraries. It makes it easier for desktop application developers to connect, which is an obvious evidence of the reusable module design
.
Decompose a large, complex application system into a number of relatively independent, highly reusable module combinations that can complete data connection by relying on only a few parameters. , is one of the most important tasks as a senior programmer and system analyst
Appropriate project design methods and clear flow charts are important guarantees for achieving this goal.
Fourth, overall project evaluation ability
As a system designer, you must be able to start from the overall situation and have a clear understanding of the project as a whole, such as the company's
Whether the resource allocation is reasonable and in place, for example, whether the project schedule can maximize efficiency without failing to complete the project on schedule
Evaluating the workload of the overall project and each module, evaluating the resources required for the project, and evaluating the difficulties that the project may encounter require a lot of experience accumulation. In other words, this is a cumulative ability that is constantly summarized. state reached.
Some leaders in software system design in the West are very old, such as 4, 50, or even older. They are far inferior to young people in terms of coding
People are so flexible, but as far as project evaluation is concerned, their decades of experience are the most important and valuable asset. China is short of such a generation of programmers. The main reason is not that programmers of that age are lacking, but that programmers of that age are basically produced by research units, and they are not from professional productization. Software development has been done
but they have not been able to accumulate experience in product development, and there is nothing they can do about it.
Fifth, team organization and management capabilities
Completing a project requires the concerted efforts of the team. As a project designer or R&D manager, you should
When it comes to maximizing the overall strength of a team, technical management is different from general personnel management due to its professional nature, as some technical indicators and factors are designed into it.
The first is the quantification of work. Without quantification, it is difficult to conduct appropriate performance appraisals, and program quantification cannot simply be calculated by
the number of lines of code, so technical management is required. People need to be able to truly assess the complexity and workload of a module
.
The second is the adjustment of the team collaboration model. Generally speaking, collaboration in program development is usually divided into groups. Small groups have the main programmer method and the democratic method. , according to the ability level gap between programmers and the needs of project research and development, select the appropriate teaming method, and be able to assign the responsibilities and tasks of members Close integration can maximize the efficiency of the team.
A person with high coding skills may not be able to become a qualified project research and development manager. The lack of ability in this area is often
easily ignored.
In summary, it can be seen that as a person in charge of R&D and a project designer, the qualities and abilities required by a project designer are not the ability to write program codes. Of course, generally In this case, when a programmer reaches this quality through continuous summary and improvement, his code writing ability is already quite extraordinary, but please pay attention to this
The causal relationship inside is that a high-level project designer is usually already a very good code writer, but it does not mean that a programmer with very good code can be competent in project design work. The problem is not IQ or textbooks, but a programmer who does not realize what he should think about when he accumulates experience and gradually improves. We consciously figure out the organization and reuse design of the project, and do not have regular documentation
habits and summary habits. If we do not change these, we are still very lacking in qualified project designers.
In addition, in order to prevent boring people from taking it seriously with me, I would like to add that the goal of this article is to do commercial software projects
Projects and engineering, those programming experts from scientific research institutions, For example, algorithm experts, such as image processing experts, their work
is to research topics rather than directly completing commercial software (of course, it will eventually become commercial products indirectly), such as Microsoft Research is working on research topics), so the quality they emphasize may be something else. These people (experts) cannot be said to be programmers and cannot be measured by programmer standards.
Finally, let me add something. What is the design process of a software project development? Take the usual standard design method as an example (but I like the rapid prototyping method).
The first step is market research. Technology and market must be combined to realize the greatest value.
The second step is demand analysis. This stage requires three things, user view, data dictionary and user operation manual.
The user view is the page style that users of the software (including end users and administrative users) can see, which contains many operational processes and conditions. The data dictionary is something that specifies the logical relationship of data and organizes it. After completing the data dictionary, more than half of the database design is completed. The user operation manual is an instruction manual that specifies the operating procedures
. Please note that the user operation process and user view are determined by requirements, so they should be completed before software design. Completing these provides constraints and guidelines for program development. Unfortunately, too many companies This is not done
The cause and effect are reversed and the order is not distinguished. This often creates a disconnect between development work and actual needs.
Requirements analysis, in addition to the above work, the author believes that as a project designer, he should complete the performance requirements of the project
Request specifications, because often performance requirements can only be understood by people who understand technology. , which requires real communication and understanding between technical experts and the demand side (customers or company marketing department).
The third step is the outline design, which initially divides the system functional modules and provides reasonable R&D processes and resource requirements.
As a rapid prototyping method, you can enter the coding stage after completing the outline design. This method is usually used because the R&D tasks involved belong to a new field and the technical supervisor cannot give clear details at first. Design instructions
does not mean that detailed design instructions are not important. In fact, after the rapid prototyping method completes the prototype code, it is based on
the evaluation results and the summary of experience and lessons. It is also necessary to redo the detailed design steps.
The fourth step is detailed design. This is an important level that tests the design thinking of technical experts. The detailed design instructions
should design specific modules in the cleanest way (black box). Structure) is provided to the coder to maximize the overall modularity of the system
; a good detailed design specification can reduce the complexity of coding to a minimum. In fact, strict
The detailed design specification should provide the definition of each parameter of each function in detail, from requirements analysis to outline design to completion of the detailed design specification, a software project should say Half done. In other words, when a large software system is halfway completed, a line of code has not yet been started. Those who simply understand software programmers as code writers have made a fundamental mistake.
The fifth step is coding. In a standardized R&D process, coding work will not take more than
more than 1/2 of the entire project process, usually 1/3 of the time. , as the saying goes, if the design process is completed well, the coding efficiency will be greatly improved. The progress coordination and collaboration between different modules during coding are the most careful. Maybe one Problems with small modules may affect the overall progress, forcing many programmers to stop working and wait. This problem has occurred in many research and development processes. Mutual communication and emergency solutions when coding are very important. For programmers
bugs will always exist, and you must always face this problem. Has the famous Microsoft ever had three consecutive bugs? Isn’t it time to issue a patch in a month?
Never!
The sixth step is testing.
There are many types of tests: according to the test execution method, it can be divided into internal testing and external testing; according to the test scope,
it can be divided into module testing and overall joint debugging; according to the test conditions , can be divided into normal operating conditions testing and abnormal conditions testing; according to the input range of the test, it can be divided into full coverage testing and sampling testing. The above is easy to understand and no more
explanation is required.
In short, testing is also a very important step in project development. For a large software, external testing from 3 months to 1
year is normal, because there will always be Unforeseen problems exist.
After completing the test, completing the acceptance and completing some final help documents, the overall project comes to an end. Of course,
Upgrades, patches, etc. will be necessary in the future. As long as you don’t want to pass a If you want to cheat money by trading with Hammer, you must constantly track the operating status of the software and continue to repair and upgrade it until the software is completely eliminated.
Writing these steps is not a show off, because to be honest, I have a copy of "Software Engineering" in my hand. In college, this is a required course for computer majors, but I know Many programmers seem to have always been only interested in "30 Days to Master VC" and the like. Some of them are from guerrilla backgrounds like me and have never formally studied this major, while others have already
After getting enough credits, I returned these really useful things to the teacher.
Fans are clamoring and confusing the public. In fact, real technical experts rarely post random posts on the Internet.
As ignorant as the author is, in fact, they are not considered What kind of master is this? I just can't stand this kind of misunderstanding and nonsense about technology and programmers
, so I have to stand up and correct the chaos. I also hope that those who are still fans can think about it seriously and leave.
On the right path, after all, those smart minds are far from being of their due value.
From programmer to engineer
Upgrading from programmer to engineer Most people like me who have a strong interest in software will go there without hesitation after graduation
Entered the company and started his career as a programmer. At that time, we were obsessed with books such as "encyclopedias" and "cheats", and we only had codes in our hearts. When I see lines of boring code turned into a device that can make calls, turned into a beautiful table on the screen, turned into beautiful music, a sense of accomplishment arises spontaneously. I think I am also an excellent programmer
. Working hard for three days and nights in the user's computer room to solve software bugs has become a qualification that can be shown off. One day five years ago
I came to Huawei after handing over a large amount of code and pitifully few documents that once made me excited and proud.
There are more young people here. I feel like a fish in water and can give full play to my imagination. It's still code, it's still hurriedly jotting down fleeting inspirations on paper (we call it documents), it's still endlessly fighting against bugs.
When one day, a new colleague came to ask me cautiously, holding a document with my name on it, I found that I didn't seem to recognize it. . I felt a little frustrated. When I looked at the code again, I found that some of the inspiration recorded in the document had changed beyond recognition. I didn't know how the new colleague felt at the time, but from then on, I seemed to realize something.
Looking back now, many things done at that time were half the result with half the effort.
I also met my project manager, a tall, thin young man who is said to have just returned from the United States and has been working there for five or six years. I was very happy after hearing this, and this time I wanted to learn both moves one by one. The requirements analysis lasted one month. The project manager discussed the contents of the proposal with us (actually on behalf of the customer) and determined that every item was required. Then he roughly divided the modules and began to enter the planned learning stage. During the learning stage, everyone has to write a functional description film and explain it to others. Unconsciously, everyone in the project team has an overall understanding of the project. learn.
He also arranged some training, such as their company's software development model and the definition of each role in the project team. In the future,
timely training will continue, as long as there is demand in the project team, He always invites QA or related people, and the training is very professional.
After the requirements analysis was completed, I submitted a document of more than 40 pages. When I saw that the parts I wrote in this English document were neatly listed
At that time, my feelings were very complicated, some joy, but more of bitterness. Why had I never done such needs analysis before?
When I was writing the document, QA trained us on the SRS writing template. Later, I was still worried and asked them.
An experienced engineer wrote a paragraph, and we Think about it again and write it down. Although this SRS was co-written by multiple people, it has the same style and detailed content. What's more valuable is that the content of this requirements analysis has not been changed until the end, so we have no chance to go through their requirements change process.
Requirements analysis is the first stage of the project, and the development time of the second stage should be determined based on the results of the requirements analysis.
When the other party’s chief technology officer (equivalent to the overall team leader of our business department) came to discuss the plan with us, they had already listed
the lines of code for each module. Number of predictions and possible risks. Based on his company's productivity of 300
works/person-month, he figured out how many weeks the second phase of the project would take.
We raised objections at the time: 1) The company has an urgent need for the project; 2) Is 300 lines per month too few? 3)
We also have the downloaded source code refer to. He explained that 300 lines/person-month is the empirical data that enables the project to meet their quality standards. Considering the source code reference, the productivity cannot exceed 350 lines/person-month at most.
When he asked about our company's productivity, I thought about it three times and didn't dare to say more. It was probably six or seven hundred lines.
He was silent for a while, and then said firmly, our plan is based on ensuring quality. I think when you come to India to develop software, the first thing you look for is our Indian company
Quality assurance. I know you have no shortage of software developers, why don't you choose downloadable software. A few words
Talking about my pain point, brothers in China are still running around for products transplanted using downloaded software!
The subsequent development activities were orderly and we followed them honestly. System test plan, use cases, outline design
Integration test plan, use cases, detailed design, unit test plan, use cases, coding, unit testing, integration testing
testing, system testing . A complete v model development process, with reviews for each process. When we didn't quite understand some design methods
the project manager sent us relevant information. I don't know what he was thinking
at that time. Some basic The analysis and design methods were mentioned in software engineering books ten or even twenty years ago. These contents are compulsory for every computer major in India. In addition to being familiar with the codes of some specific protocols, we seem to know nothing about these commonly used methods. I felt a little ashamed, so I went straight to the bookstore in the city and found the books he listed for me. I lay in bed at night and studied them carefully. It seemed that I suddenly met a good person who could give me some guidance. Teacher and friend
Friend. Now India has formed a strong learning atmosphere. After I came back, I also promoted more than 700 books. These books teach us how to develop software using engineering methods. They are must-read materials for becoming a software engineer.
Our project manager has strong planning and control capabilities. When something happens that affects the project plan, such as
resignation of personnel, relocation of the laboratory, or failure to predict a certain module. Accurate (this module is what we predict), he always takes necessary measures to reduce delays and adjust plans. At first, we had some objections to them going downstairs to drink coffee at 11 a.m. and 4 p.m. every day.
We also started drinking coffee later. It turned out that the exchanges over coffee were very rich, from project management to Design
Methods, covering everything from technical development to local customs, are very helpful to our understanding of each other and the atmosphere of the team
. The QA of our project also appeared in front of us at the appropriate time, and we only had some perceptual understanding of her work.
Every time she attends a meeting, she always holds a checklist in her hand. The project manager prepares the corresponding information.
To answer some questions, she ticks the boxes or writes the project manager's explanation. She was also very patient when giving us training, which showed
very good professionalism. I still miss the help she gave us.
I have been engaged in software development for nine years, but I still cannot say that I am a qualified software engineer
Let alone a qualified manager.
I saw a report that an authoritative organization in Lausanne, Switzerland, moved China's comprehensive competitiveness in science and technology from the original 13th place to more than 20th place because they adjusted some evaluation criteria. One of them is that the availability of qualified engineers in China is very low. Thinking of the red eyes of the brothers and the tired figures running around for upgrades
I have a strong desire: Let’s upgrade ourselves to qualified engineers quickly!