The first time I translated an article, I wanted to share this article with everyone because a newcomer in the group asked for advice about which frame to learn. All I could think about was getting a cup to drink more water, getting a better chair to protect my waist, reading more source code and wandering around the community. Suddenly, in addition to the technology, there are a lot of work experience, learning methods, people things are also important, even before the technology. However, there are not many articles about these things, so when I saw this article yesterday, many of the suggestions in it are exactly the solutions to the problems I face. I felt it was necessary to share them with more people, so I sought the authorization of the author of the original text and translated them as soon as possible.
Dev. To/EmmaWedekin…
As a reader here, I personally find most of the advice in this article very useful, but some of it is similar and can be combined and sorted haphazard, which makes it a bit too long. It is also important to make a flexible judgment of some suggestions based on the domestic situation. I will also mark the points that I think are more important on ⭐.
Step over the wall if you follow the rules
This is my special for domestic programmers to add, we should understand, otherwise the first will stop.
1. Use Google ⭐
As a programmer, you need to know how to search for answers to questions. Learn to use Google effectively and you’ll save a lot of development time.
2. Careful commitment to overdeliver ⭐
It’s better to let your team know that a task will take three weeks and be completed in two weeks than to let them know the opposite. By carefully committing and overdelivering, you build trust.
3. Be nice to product designers, they are your friends
Product designers provide solutions to users’ pain points. Learn from them and work together to build products that work.
Find a mentor
Find someone to learn from and learn from. Coding Coach is a great place to go if you need technical guidance.
5. Become a mentor
Be someone others can learn from and learn from. You can try being a mentor at Coding Coach.
This website is not very understanding, please consider yourself. Domestic formidable programmer is also a lot of, dig gold, zhihu can also find.
6. Write useful reviews
Writing down useful answers instead of asking why, Mark and irrigation are also not interesting.
7. Name variables and functions properly
Functions and variables should accurately represent their purpose, so myCoolFunction is not a good name.
8. Take a vacation
We all need time to deal with stress. Take a vacation somewhere you’ve always wanted to go. Your brain and colleagues will thank you.
9. Delete useless code ⭐
There is no reason to accumulate more technical debt.
10. Learn to read the code ⭐
Reading code is a very valuable and undervalued skill.
11. Find a healthy work-life balance
After a week’s work, relax on weekends. Turn off work notifications and delete apps from your phone.
12. Schedule only necessary meetings
Meetings that can be handled by email are not necessary, and if they must be held, they should be short and effective.
Pair programming
Pair programming lets you play the role of both teacher and student.
14. Write your email
Your email should be short, clear and to the point. No one wants to read four pages of your E-mail, bro.
15. Join the community ⭐
Being around like-minded people will help you get out of your slump.
Clean up your branch ⭐
Clean out your version control branch the same way you clean out your house before your in-laws visit. If you no longer need it, please delete it and save it for next year.
17. Embrace the new
Be inclusive and don’t tell people they’re not good enough to get into the industry. Every man is worth something.
You are never too old to learn
You choose a profession that requires constant learning and learning to love it.
19. Never give up
It’s not easy, but we’re all starting from the same place, and you can do it, too.
20. Dare to accept challenging tasks ⭐
If a task isn’t challenging, it won’t help you grow.
21. Identify requirements before the project begins ⭐
Before starting a masturbation session, you should know the acceptance criteria, which will save you time and pain.
22. To do a good job, you must sharpen your tools ⭐
Have a set of tools that you are familiar with, know which tools serve which purposes, and when your project can benefit from using them.
We need constructive criticism
Seek constructive criticism from trusted colleagues and friends. It will help you excel.
Keep an open mind ⭐
Technology is changing, and it’s changing fast. Don’t be against new technology, learn it and form your own opinion.
25. Stay on the cutting edge of technology and don’t fall behind ⭐
Stay up to date on the latest tech news by following publications, blogs, podcasts, and tech news.
26. Focus on solving problems ⭐
Exercise your problem solving skills. Strong problem solving skills will help you cope and focus on solutions.
27. Be humble ⭐
No matter what your title or company, stay humble.
28. Not only should you write good code, but you should also make good powerpoint presentations
Learn how to engage your audience and give an effective presentation.
29. Selection such as buying vegetables, also want to shop around ⭐
Give yourself more options and research as many solutions as you can before you start.
30. Find your niche ⭐
The tech industry also has many categories. Find the field that interests you most and become an expert.
31. Form good habits ⭐
Try to establish consistent, healthy habits like staying focused, managing your time, attending meetings, and starting with the most important tasks. It may take some getting used to, but it will be worth it in the long run.
32. Learn to debug ⭐
Explore the browser debugger tools. Learn the ins and outs of IDE debugging. Even the most difficult bugs can be solved by learning the most effective ways to debug problems and track down errors.
33. Hone your existing skills ⭐
Just because you’ve mastered a skill doesn’t mean you don’t need to practice it. Practice makes perfect, but lack of play. Skills will disappear over time unless you consciously improve them. And the industry is growing so fast that it’s important to keep practicing. Get out of the “I’ve always done it this way” mindset and into the “is there a better way to do it?” mindset.
Just because you now have a six-pack doesn’t mean you can eat 🍩 every day.
34. Find out why ⭐
Sometimes you have to voice your opinion, so it’s important to understand the reasons behind it. Why is solution A better than solution B? Provide valid arguments and your opinion will be more reliable.
35. Know your value
Technology is a commodity and should be paid appropriately. Know the industry average in your area. If you’re making less money, it’s time to talk to your boss and go after what you deserve.
36. Don’t be afraid to ask for help ⭐
If you’re stuck on a problem and spend too much time looking for a solution, it’s time to ask for help. We’re all human, we all need help, and there’s no shame in asking for help from colleagues.
37. Learn to learn ⭐
People learn differently. Some learn best through video tutorials, others learn best by reading books. Figure out your learning style and practice it.
38. Be kind
Sometimes you will be asked to give feedback to a colleague. Be nice and you can express your opinion about a colleague’s lack of positiveness rather than being rude.
39. Take a break
Typing code for 8 hours in a row is almost impossible, and you’ll soon tire out and make a lot of mistakes. So set an alarm to remind you to stop and take a break. Going for a walk, having a cup of coffee with a colleague and getting away from the screen can have a positive impact on your productivity and quality of work.
40. Track your progress
Learning to program takes time, and it can be very frustrating when you don’t see progress. So it’s important to track your accomplishments and progress toward your goals. Keep a small list next to your computer, and every time you complete something, write it down, no matter how small it is, it will eventually change from quantity to quality.
41. Don’t rely on libraries and frameworks ⭐
Learning a framework or library is not as good as learning the language in depth. There is no need to learn one library or framework after another, but understanding how frameworks or libraries are implemented can help you write cleaner, stronger code.
42. Learn to love code reviews
Having someone else read and analyze your code may be unsettling, but it can provide valuable feedback that will make you a better programmer. You should also improve your ability to conduct good code reviews.
43. Learn in all directions
Learn the basics of other areas, such as design, marketing, front-end or back-end development. It will help you become a more rounded programmer.
44. Don’t choose a familiar technique, but the correct one ⭐
Each project has different requirements, so we must choose the right tools for the job. Although it is convenient to choose previously used technologies, alternatives should be explored if they do not fit the needs of the project.
45. Take responsibility ⭐
Everyone makes mistakes, and you will make many, many mistakes throughout your career. So when you make a mistake, it’s important to step up and take responsibility, and it will build trust with your team members and management.
46. Check your code ⭐
Before making a PR request, review your code. What would you say if it was a colleague’s work? It’s important to first try to diagnose a problem or bug yourself before requesting a code review, just as you should check your test paper before handing it in.
47. Learn from failure ⭐
Failure is simply not achieving the desired result, not necessarily a bad thing. We will face many failures in our careers and learn from them what you can do next time.
48. Acknowledge your weaknesses
Know yourself. What are your weaknesses? Maybe you always forget to update your tests before you push them, or maybe you’re just not good at answering emails. Know your weaknesses so you can actively work to improve them.
49. Be curious ⭐
The industry is growing, so curiosity is important. If you don’t understand something, whether it’s a project requirement or a line of code, speak up. No one will criticize you for asking for instructions, and you’ll make better code for it.
50. Don’t try to learn everything ⭐
There is an endless store of knowledge in the world. You can’t conquer it. Choose a few topics to master and leave the rest alone. You can gain knowledge in other fields, but you can’t know everything.
51. Give up when you have to
Just because you write some code doesn’t mean you need to feel emotional about it. No one likes the work they do thrown away, but code has a life cycle, so there’s no need to keep it all the time.
52. Team support
Great teams support each other, which creates a safe space to try new things without fear of punishment.
53. Find inspiration in your community
Find a few people in the industry that you admire. It will motivate you to continue your project or try something new
54. Value and cherish your work
No matter how much experience you have or what your title is, your work is valuable and give it its due.
55. Eliminate distractions
Turning off idle notifications, texts, emails, and social media will help you focus and maximize your workday. Answer your friend’s text 30 minutes late, he won’t die, so he’ll call.
Be willing to help others
Try to support your team members, whether it’s attending an important presentation or helping them when they’re going through a rough patch.
57. Be generous with your compliments ⭐
If someone is doing a good job, tell them. Positive feedback is a great way to build trust with your team members and help advance their careers. They are also more likely to help you
58. Test your code ⭐
Testing is important. Unit testing, regression testing, integration testing, end-to-end testing. Test your code and your product will be more stable.
59. Develop a response plan
When you receive a request for a new feature or a bug change, make a plan. What do you need to fix the problem or develop the feature? Taking a few minutes to do this may save you hours of frustration later.
60. Master pseudocode
Pseudocode is a great skill because it allows you to think about complex problems without wasting time writing code. Put a method on paper, run different test cases, and see where the bugs are.
Keep track of your accomplishments
If you receive an award at work, write it down. If you develop an important feature, write it down. You’ll have some accumulation that will help you advance in your career or boost your morale on a tough day.
62. Learn the basics of programming ⭐
Learn some basic sorting and search algorithms and data structures. They are language independent and can help you solve problems across languages.
63. Choose a technology for long-term maintenance
While it is fun to test the latest technologies, choose technologies that are easy to maintain in enterprise applications. Your team will thank you for years to come.
64. Learn design patterns ⭐
Design patterns are an effective tool for building code. You may not need them for every project, but a basic understanding of them will help you build larger applications.
65. Simplify things ⭐
Don’t write complex code to show off your programming prowess. Focus on readability and simplicity. This will make it easier for your team members to contribute.
Pay off technical debt
Technical debt can have a huge impact on performance, so if you can refactor, you should. (This is definitely good advice, but there are a lot of problems in reality.)
67. Prioritize small version iterations
Instead of releasing large upgrades once a month, release smaller changes more frequently. This way you are less likely to introduce bugs and break changes.
68. Submit ⭐ early and often
Committing early and committing often is the best way to ensure your work stays clean, and also reduces the stress of unintentionally recovering important changes.
69. Know when to ask for help
Not only should you not be afraid to ask for help, but you should learn when to ask for help. Before asking for help, you should try to solve the problem and document what you are trying to do. But when you’re stuck on a simple question for more than an hour and the costs outweigh the benefits, you should ask your colleagues for help.
70. Ask effective questions ⭐
When you ask questions, be as specific as possible (see the Github issue requirement).
71. Ask for feedback at work
Your work doesn’t need to be done to get feedback. If you are unsure of direction, bring in a trusted colleague to check the effectiveness of your solution.
72. Read the documentation ⭐
Documentation is the purest source of facts about a technology, so learning to read it can quickly help you become an expert.
73. Try everything you can ⭐
There is nothing to stop you from trying to solve the problem, what do you have to lose?
74. Speak up actively at meetings
Your ideas and opinions are valuable, so attending meetings will help you build rapport with your team and management.
75. Work across teams
If you have an opportunity to work with another team in the company, go for it.
76. Stay enthusiastic
When you’re working 40 hours a week, it’s important to spend time on projects that interest you (especially if it’s 72 hours). They can help you rediscover your love of programming and try out new technologies that you might not have access to at work.
77. Determine your career goals ⭐
It’s important to have an ideal trajectory for your career. If you don’t, you’re shooting without a target.
78. Join the discussion ⭐
Commenting on blogs, tweeting, participating in community events, and being an active observer will teach you more than just watching.
79. Prioritize tasks
Learning to prioritize tasks will help increase your productivity by building a to-do list for daily and long-term tasks and ordering them in the most important order.
80. Don’t lose sight of details
Details can make a big difference in a project.
81. Trust your colleagues
Your colleagues are hired for their skills, give them work, and trust them to get it done.
82. Delegate
If you are in a leadership position, learn how to delegate effectively. It will save you time, you can’t do everything.
83. Don’t compare yourself to others
The only person you should compare yourself to is yourself yesterday.
84. Find your Allies
Learning to code will be a long and not easy process, surrounded by people who help you grow and encourage you to keep going.
85. Don’t try to jump to the top ⭐
Thinking too much at first about doing a big, comprehensive project can overwhelm you. Build with scalability in mind, but scale only when you need to. This way you don’t overwhelm your team with unnecessary bloat, but instead maintain the ability to grow.
86. Measure performance impact ⭐
If you want to use a cool new technology, you should weigh the performance impact of doing so. Can you do something similar without affecting performance? If you can, you may want to rethink your approach.
87. Technical discrimination is undesirable ⭐
Don’t discriminate against new technology or ideas, be open to the possibility of learning new skills, and don’t discriminate against others. We all deserve respect. (Don’t discriminate against old technology either, even though front-end frameworks are all the rage these days, you can’t say Jquery doesn’t have any redeeming qualities.)
88. Apply for jobs you’re not qualified for
You’ll never meet all the requirements for a job, so take the chance and apply. What do you have to lose?
Modularize your code
You can write all your code in one long file, but that’s not maintainable. By modularity, we ensure that the code is easy to understand and test.
90. Don’t just be a code porter ⭐
If you’re going to copy and paste a solution from Stack Overflow, you should understand exactly what it does and consciously choose the code to introduce.
91. Create a comfortable working environment ⭐
If you like your work environment and technology Settings, you’ll be more motivated to work, so what are you waiting for?
Remember where you come from
We all start at the same place, and as your skills and position develop, don’t forget where you came from and don’t inflate.
93. Try to keep optimistic
If something goes wrong, try to be optimistic. Tomorrow is another day. Optimism will help your team feel energized and mentally healthy.
94. Constantly re-evaluate your workflow ⭐
Just because something works now doesn’t mean it will work forever. Re-evaluate your workflow and make adjustments if necessary.
95. Learn to work from home
If you have the ability to work from home, learn to work from home effectively. Find a separate office space away from distractions. Boneskull wrote a great article about working from home that you should check out.
96. Accessibility codes
Accessibility is not an afterthought, nor is it necessarily difficult, and everyone should be able to use your product.
97. Keep your promise ⭐
If you tell someone you’ll get something done by a certain day, keep your promise. If you can’t meet the deadline, say so early.
98. Be proactive
If you have extra energy, find a task to help your team, they will appreciate you taking the initiative.
99. Create an amazing portfolio
An excellent portfolio sets you apart, use it as an opportunity to showcase your programming and design skills!
100. Remember why you like programming ⭐
You got into this industry because it piqued your interest, and if you’re feeling frustrated and resentful, take a break and give yourself the space to rekindle your passion for programming.
101. Share your knowledge ⭐
If you’ve learned something cool, share it. Go to a local tech meeting and teach your colleagues or mentee over lunch. Sharing your knowledge can benefit more people and strengthen yourself.
End scatter flowers 🎉🎉🎉
That’s all my advice about being a good programmer. I hope you enjoy it.
The last
There are 102 rules for proper exercise and 103 rules for adequate sleep. As programmers work for a long time, they will increasingly realize the importance of these two rules, so there may be some constructive suggestions below.
Some of the content in this translation has added some personal understanding, if you feel that the translation is not appropriate, please feel free to comment and give your advice on becoming a good programmer.