開源日報 每天推薦一個 GitHub 優質開源項目和一篇精選英文科技或編程文章原文,堅持閱讀《開源日報》,保持每日學習的好習慣。
今日推薦開源項目:《那你很棒棒哦 emoji》
今日推薦英文原文:《Why Every Junior Developer Needs A Senior Developer》

今日推薦開源項目:《那你很棒棒哦 emoji》傳送門:GitHub鏈接
推薦理由:推薦閑得無聊時嘗試的項目,允許 Python 在命令行界面輸出表情。即使是用於和其他項目一起食用,多加這麼一個依賴項換一個表情包功能似乎有些華而不實……不過在娛樂的時候就不要想著這些了,只要不是用在比較正式的地方,娛樂性強的項目就是應該怎麼開心怎麼有新意怎麼玩的。
今日推薦英文原文:《Why Every Junior Developer Needs A Senior Developer》作者:SeattleDataGuy
原文鏈接:https://medium.com/better-programming/why-every-junior-developer-needs-a-senior-developer-2cd989058e06
推薦理由:實踐經驗在軟體工程中很重要,從熟練工身上吸收這些經驗能夠減少初心者踩坑的機會

Why Every Junior Developer Needs A Senior Developer

Avoiding unmaintainable code, bad projects, and bad expectations

The concept of mentorship of a senior developer to a junior developer is often looked at as beneficial to the junior developer. However, pairing a senior developer with a junior developer is not only beneficial for the junior. It is actually quite beneficial for the company who intentionally pairs both engineers together.

Senior developers who have worked on multiple projects have a much deeper understanding of how to develop maintainable systems and code. They have a good sense of which projects are worth doing and can help manage stakeholder expectations. All of this boils down to them being able to see around corners and keep junior engineers from building software that is overly complicated and doing work that might have little to no impact for the company.

This all impacts the company』s bottom line. Yet, it doesn』t seem like every company does this. I recall my first job, where I was the only technical person on my team and had to support five analysts. Honestly, I doubt anything I built is still maintained today because I often built only to meet some functional requirement, and there was no one there who could provide input into design, maintainability, etc. (Luckily this changed at my next job.)

That said, I want to lay out three reasons it』s very important to pair junior developers with senior developers. Again, this isn』t just so the junior developers can grow; this is to ensure the software being built is sustainable and has the right features that will benefit the company.

To Know What Is Maintainable


https://www.monkeyuser.com/2018/workaround/

Have you ever built an automated process, website, or framework on your computer? Now, have you ever taken that same new system and implemented it into a larger system where there might be thousands, maybe millions of users. Then … have you had to maintain it for multiple years?

If you have, you know it is several magnitudes more difficult to develop a system that is sustainable. You have to constantly make design decisions that have pros and cons. Sometimes, due to time or technical constraints, you might need to circumvent certain limitations. This can lead to technical shortcuts and some tech debt being taken on. All those small shortcuts you might take and bad design decisions you don』t think through can quickly come back to bite you (like it did at Chernobyl).

Even doing something small like changing an integer column to a float could be a weeklong endeavor between finding all the fields references, updating them, and then running tests.

Creating maintainable and sustainable code all starts with good design. However, many junior developers will either start coding or forget to think of important aspects about a design. This is where senior developers can step in and help guide junior developers in design reviews and pair programming.

Having a senior developer provides insights into the possible pitfalls a junior developer』s design might have. They won』t see every problem, but they can help think through edge cases that the junior missed. In turn, this teaches the junior developer what they need to think through in the future.

To Help Manage Expectations

Many of us who built our first programs in college often built websites, applications, and side projects in a few weeks. However, once we started working in the industry, it felt like what used to take a few days or weeks suddenly started taking months. Suddenly, the concept of project management is very important.

Simple requests for changes or updates required a lot more than just updating code. An entire analysis often needs to be done to see how a change might impact modules downstream. Suddenly, a code change that would have been quick and simple can take a much longer time because it could have multiple downstream dependencies.

Being able to manage these expectations helps ensure that the development teams aren』t overpromising timelines. I recall promising timelines that took weeks for projects that would have taken several months.

The problem is you run into issues like people going on vacation, operational tasks that get in the way, meetings, and other normal daily functions that take tasks that might seem quick and extend them greatly over time.

Senior developers are more accustomed to these distractions and can come up with more realistic expectations. Don』t get us wrong, management will probably still cut the timeline in half. But at least you tried!

To Know What A Bad Project Is


https://marketoonist.com/2018/05/being-agile.html

Knowing what might be a bad project is a difficult skill to acquire. This is why a junior developer won』t know when they』re asked to work on something that might have little to no impact for the company or prove too large to take on by themselves.

Bad projects aren』t often obvious. They can start as one-off initiatives that a new director feels will improve the company even though it doesn』t line up with current goals. It could be a hype project where some salesperson went to a conference, heard about some new AI feature, and is now demanding the engineering team add it to their products.

Wherever the source, these projects lead to unnecessary stress and often features that don』t provide value to the end user. Having a senior developer who can spot some of the characteristics of bad projects and show them why the project isn』t an effective use of time will help improve the company』s bottom line.

Conclusion

Overall, there are a lot of other great reasons to pair junior and senior developers together. But, as someone who has been a junior developer and was provided no senior developer to act as a guide, it was not only detrimental to my growth but also to the impact I had on the company. It』s really hard to tell when you』re making a bad decision because you have never been there before. There are so many assumptions and decisions that engineers need to work through, and without the experience to guide you, you can quickly find yourself in a bad situation. Again, this doesn』t just cost the junior developer; it costs the company.
下載開源日報APP:https://openingsource.org/2579/
加入我們:https://openingsource.org/about/join/
關注我們:https://openingsource.org/about/love/