Original: www.cnblogs.com/coder-thoug…
With the rapid development of the Internet and mobile Internet, all kinds of applications (APPS) have sprung up like mushrooms, many of which have even become super apps, and some of which have more than 100 million active users have become national apps. The rise of these apps is inseparable from the group of programmers. Fast-growing industries, the aura of Internet giants, the sense of accomplishment that comes with national apps, and salaries that go far beyond the average industry are attracting large numbers of programmers every year. The competition is getting more and more fierce, the 35-year-old threshold for programmers has become a perennial topic of discussion on social media, and midlife angst has become the norm for programmers. What core competencies should we build as programmers to get rid of anxiety and stay relevant in the long career path?
Today I’m going to talk about one of the things I’ve learned in my 10 + years as a programmer.
From basic to advanced, I will summarize three aspects: general ability, professional ability and advanced ability.
01 General Ability
General ability is the basic ability that all employees need to possess. General abilities include learning ability, communication ability and executive ability.
- The ability to learn
In the Internet industry, technology changes with each passing day and is constantly upgraded; 3G and 4G have gradually gained popularity in the past 10 years, and 5G is coming soon, which brings higher and higher requirements for IT-related technologies. From the programming languages and technical frameworks we use every day to more complex communication protocols, audio and video coding and decoding, network data transmission and so on, various technologies are constantly updated and improved. As a programmer, we will also be in different sub-industries, companies, contact with different businesses and products, quickly learn and understand the logic and nature of different businesses and products, is a necessary quality. All of these require at least a passing level of learning ability, continuous learning, grinding technology, enrich their skills, to adapt to the rapid change of The Times brought technological updates and challenges.
- Ability to communicate
As a programmer, most of the time is dealing with machines, but it does not mean that programmers can be completely isolated from the outside world, good communication skills, can make work twice the result with half the effort. Many programmers will reject communication with people, always want to show and express themselves through the code, the product made, in some cases may work; But in most of the work, we still need to communicate and communicate with others, such as requirements review need to communicate with product students, bug need to communicate with testers, even code needs to make a good technical architecture design, through words, graphics or language expression. Communication first requires the willingness to communicate.
Secondly, we should master good communication skills and learn to put ourselves in others’ shoes to avoid unnecessary conflicts. As the post-90s and millennials enter the workplace, the society is becoming more and more tolerant and advocates a diverse and free culture. One problem brought by this is that more and more people tend to be self-centered, closed or even extreme, which is directly reflected in the frequent conflicts between them and others in social and professional communication, making teamwork more and more difficult. Therefore, mastering good communication skills and learning empathy is also a reflection of communication ability.
- Executive force
Any team and organization will require everyone to go all out after the goal is clear, carry out the established plan to the letter, and complete the task with high quality and efficiency. Therefore, good execution is also the basic ability that programmers must have in a team.
These are some of the basic skills you need to be a programmer in the workplace. In addition, I think programmers need to build the following expertise.
02 Professional Ability
Professional ability is the key for programmers to enter the IT industry and engage in software development. The difference in professional ability also means that different career heights can be achieved. Professional competence includes basic technical competence, architecture design competence and project management competence.
- Basic technical ability
Basic technical skills are the foundation on which a programmer lives in his job. For a Java programmer, you need to have an in-depth understanding of Java syntax, JVM principles and tuning, Java’s advanced features, and so on. Need to understand common data structures and algorithms; Be familiar with mainstream application frameworks, such as Spring, Spring Cloud, Spring Boot, etc. Hands-on experience with common middleware, such as caches, message queues, NoSQL databases, and so on; In addition, it is necessary to have some research on database, operation and maintenance technology. If you have a good grasp of basic technical skills, you can get a job offer.
- Architecture design ability
The ability to design architecture is the first hurdle a programmer needs to overcome to break through himself.
One of the new problems with technology and frameworks is that many programmers can already get most of their work done by simply copying and pasting. There is also a term called “Crud Boy”, which refers to a programmer who simply adds, deletes, changes and checks most of the time. Repetitive copy and paste or Crud makes the programmer’s mind degenerate, unwilling to think, and facing the dilemma of being eliminated over time. If in the work, can think more and summarize, gradually accumulate the ability of architecture design, then the result may be a different situation.
Architectural design capabilities begin with the simplest design patterns. When writing code, have you considered effectively organizing the code and refactoring it according to the 23 design models advocated by GoF to make the code more readable and maintainable?
Secondly, we need to master the idea of hierarchical design of the system. The front and back end are separated, and the presentation layer, control layer, and model layer play their respective roles. Whether you are post-development or front-end development, the mainstream frameworks such as springMVC, Vue, etc., all tell us the importance of layered design. Similarly, when you design a system architecture with a large number of users, it is necessary to reasonably divide the system into access layer, interface forwarding layer, service control layer, service execution layer, cache layer, data access layer, etc.
Thirdly, for the system with high concurrency and large flow, it is necessary to master how to do service division and module separation, identify domain boundaries, and support horizontal expansion and vertical expansion while achieving high coupling and low cohesion. At this time, more in-depth research is needed on distributed services, microservices, RPC, database sub-database sub-table and other technologies.
Finally, you need to know some disaster recovery and backup solutions. What can I do if the equipment room where the application system resides or the cloud storage network is faulty? What happens when database data is deleted by mistake? How to deal with force majeure natural disasters in some regions? These are the points that must be taken into account when the scale of access, user, data etc. reaches a certain scale.
Architecture design capabilities can be extended segment and again, for example, as the trill, the rise of video and broadcast applications such as well quickly for large flow rate of the video, graphics, image class how to design the system architecture, with the advent of the era of 5 g and AIoT, how to design the system hardware to support large scale and very large scale of Internet of things terminal access and data, and so on. Above these architectural design capability in each dimension can delve into the mining technology points, if you have time and want to breakthrough unceasingly, should go deep into the each field, through continuous research and practice experience, until one day you can according to different business, application scenarios, such as user, design a set of reasonable architecture.
- Project management ability
Another professional competency is project management.
Project management ability is a comprehensive ability.
Many people have the misconception that project management is a simple skill, or that it is not a core skill that programmers need to have. In some big Internet companies, there are special project managers or similar PMO organizations to promote and complete the project management work, but this does not mean that a programmer does not need to master the project management ability. Project management is a thing that any organization must do well to complete products and successfully launch projects. For a programmer, whether he can lead or be responsible for completing the project management of a medium or large project or complete the project-related management work in a subdivision of the project, is the embodiment of comprehensive ability. In recent years, whether it is baidu, quickly gala marketing technical support team, or jingdong, taobao double tenth annual technical support support team, they are massive, across teams, cross-regional large projects, in these projects, from top to bottom all need different areas, different organizations, horizontal and vertical project management personnel, And these project managers are often experienced programmers, technical experts grow up. They need to project target, the strategic significance to understand very well, organization completes the project target segment alignment, task decomposition and floor plan, coordinate projects in all kinds of resources to break through the technical bottleneck and difficulty, completes the project risk management, and overall consideration to do the team atmosphere, form a project team together, ultimately responsible for the project goals.
If you have all these skills, you can go from being a novice programmer to being a technical expert, and most of the technical problems you encounter in your job can be solved by yourself. If you are still not satisfied and want to improve yourself further, you need to develop the following advanced skills.
03 Advanced ability
Advanced skills are necessary for programmers to move to the next level and break through the workplace ceiling.
Advanced skills include breadth of technology, systematic thinking, team management, organization and coordination, and business understanding.
- Breadth of technology
Everyone’s energy and time are limited, when we have a deep enough understanding of our professional field, we need to expand our knowledge. As a programmer, in addition to completing architecture design and coding, I will also be exposed to more professional technical fields, such as security, big data, algorithms and AI. On the one hand, expanding these areas of expertise can promote a deeper understanding of the basic expertise of programmers, while also gaining new knowledge and breakthroughs in other technical areas.
- Ability to think systematically
After having a certain depth and breadth of knowledge, they can jump out of a specific technical detail and make systematic thinking and summary. They can sort out and establish their own technical knowledge system and form their own methodology to solve problems by drawing inferences from one another from the field vision and global perspective. As systematic thinking ability, technology or knowledge like snowball, quickly identify, extract, learning, accumulation, cycling, establish a system of technical knowledge constantly updated iteration, no matter how changes in market, business, technology can timely adaptation, dividends even grasp new technology, to lead the development of new technology.
- Team management ability
When programmers reach a certain stage of development, they must face the possibility of becoming managers. Some people will become the leader of a team of 3 to 5 people, and some will lead a team of dozens or even hundreds of people. Some students refuse to take management positions because they only want to write programs, but this does not mean that they do not need to pay attention to the improvement of team management ability. Everyone is the team management participants and affected, through good team management ability to give play to the value of the team, can make the programmer’s work more meaningful.
The construction of team management ability includes the precipitation of management methodology and the landing of management action. These two aspects complement each other and promote each other.
The precipitation of management methodology, the first need for leadership training. Leadership should be your guiding principle in managing your team. Different organizations will build their own leadership models. In a leadership model THAT I have learned and practiced, LEADERSHIP is explained in terms of three dimensions and six fields. Here I would like to share.
The main goal of leadership is to organize coordination and exert the strength of the team to achieve performance results. What does leadership focus on?
1. Managers need to understand the company’s strategy and direction, and formulate team goals according to the company’s strategy and direction. Any organization needs clear direction. When you become a team manager, you need to understand both the long-term goals of the company — what we call the vision — and the short-term goals of the company. Guide the long-term efforts of the team with the vision of the company, break down the short-term goals of the team according to the short-term goals of the company, and make the short-term goals of the team to guide the work of the team in the next half year, quarter or month. We can manage the team’s goals through different management by objectives approaches such as OKR.
2. Good incentives are needed. Motivation can make team members more motivated to work. Short-term motivation can be achieved through rewards, praise or praise on a daily basis, while long-term motivation needs to be achieved through expected management and work empowerment of team members.
3, need to do a good job in the guidance of team members. Provide guidance and assistance to team members through daily coaching, and identify the target employee portraits that team members need to learn from in the future by setting an example. Leadership is ultimately delivered through action plans, not just slogans and written summaries, which will be explained later.
Leadership is a very big topic, and everyone who is interested in it can study it in depth to find and establish a leadership model suitable for himself.
Secondly, with the guidance of leadership model, we also need to do a good job in team talent inventory and echelon construction, identify the stars, potential, backbone and underachiever in the team, and promote the continuous improvement and progress of team members through goals and performance while knowing the team members well.
Third, do a good job in team process and mechanism precipitation. For a team to run efficiently, it depends on proper processes and mechanisms. On this point, I have seen a very concise summary: simplify the complex things, standardize the simple things, streamline the standard things, and automate the process things. It elaborates the truth that is to do the process, mechanism precipitation, can finally achieve the maximum efficiency.
Fourth, we need to manage upward. Understand your supervisor’s expectations of you and your team, know how to ask for help through superior coordination resources, and at the same time, be able to consider problems from the perspective of your supervisor, and share the burden of solving problems for your supervisor.
Finally, establish a distinctive team atmosphere and team culture. A good team is inseparable from a good team atmosphere and culture, which can also attract and filter like-minded people and promote the continuous development of team atmosphere.
With the precipitation of management methodology, it does not mean that management can be done well. It is more important to influence the team through the landing of management actions in daily work.
We need to refine management methods and tools for every environment and every action at work.
For example, annual, quarterly and monthly goal setting and regular review can improve team members’ sense of goal and team cohesion. Regular one-to-one communication, understand the ideas and confusion of team members, and give them guidance and help. Organize review reviews of project and requirements iterations, identify problems during requirements iterations, identify points where processes can be optimized and develop repeatable and reusable methodologies. Regular team performance review and team member performance feedback, let everyone know how to improve. Organize team technology sharing, participate in technical exchanges in the industry to build team and personal technical influence, and build team geek culture, etc.
In the process of management action landing, knowledge gained through practice can enrich management means and management toolbox, and then summarized into a new management methodology to guide the next stage of team management.
- Organization and coordination ability
There are similarities and differences between organization and coordination ability and project management ability. They are similar in that they emphasize the importance of teamwork and achieving goals through teamwork. The difference is that the project management ability is more focused on the project, everything around the project goals. Organizational and coordination ability emphasizes organization and people. Compared with project management ability, organizational and coordination ability is a higher level. Any project or task will no longer be a problem when you have built up your organizational and coordination skills. The ability to organize and coordinate requires you to understand the organization and its departments and personnel, quickly identify key people and core objectives, establish connections within the organization, and improve your influence within the organization. Can well understand and listen to others, empathy and empathy. When you need to complete a task, take advantage of your organizational and coordination skills, grasp the key points, find the key people, and success will follow.
- Business understanding
Technology itself does not generate value, but only when it is applied to the business and products that address users’ needs. As a technical programmer, stand in the perspective of the business to think about the problem, to solve the business pain point is always the first. Programmers can not only be satisfied with the passive completion of business requirements, but also need to take the initiative to understand and think about business, insight into the core and essence of business, business problems into technical problems. At the beginning of the business, the rapid build MVP version of the product, to support the business development, or stable stage in business development, through continuous abstraction, modular, create as a service, platform technology system, supporting large-scale expansion of the business, let technology truly play support even drive business transformation. Finally, summarize the above explanation with a picture.
Beige has proved through years of practical experience that these core abilities of programmers are interwoven and progressive in their work, and we use, learn and accumulate these abilities every day. Through continuous summary and review in the work, accept the experience of projects and products, I believe that everyone can break through themselves, to a new level.
Of course the core competencies of a programmer vary from person to person, just as there are a hundred Hamlets in a hundred readers’ eyes. The important thing is for everyone to summarize their work and find their own circle of competence.
Please feel free to contact me if you have new knowledge or different views on the core competence of programmers.
Zero Basic Learning Java recommended personal ten years Java learning garden.