The original address: Characteristics of a Bad Software Engineer | by Manish Jain | Aug, 2021 | Level Up Coding (gitconnected.com)
Know yourself and your enemy, and you will win a hundred battles
There’s been a lot of talk about what makes a good engineer, or a senior developer, or something nice. Let’s take a look at some of the things that a good engineer shouldn’t do. The bad qualities, the habits that will hold you back, and the mindset that will prevent you from becoming a better engineer.
Start the music, start the dance.
High speed mass
Sam is a developer who likes to develop and deliver requirements quickly. He often delivers requirements on deadline, and whenever he gets stuck, he does a quick Google search and applies the first solution he finds.
The problem here isn’t picking up the first solution from Stack Overflow or anywhere else. The problem is applying it mechanically without understanding the consequences. Applying something without fully understanding the context can lead to more problems in the future.
A lot of times I’ve seen people think that getting things done quickly will help them get ahead of others. They may impress people in the short term, but in the long term, they will fail because they do not have a deep understanding of the problem they are solving.
test
Sam is a great developer. He loves programming, but he hates writing tests. According to him, this slows down development, and why bother with QA to test the code anyway.
Writing tests can be cumbersome at times, but as complexity increases and requirements change, it becomes more difficult to maintain the code if you don’t have a safety net. It may be a lack of interest in setting up test environments, or it may be a lack of consistent testing knowledge.
The code will take longer than you work on it. You should make sure it does what it’s supposed to do, no more, no less. Maybe the next time you estimate a feature, you’ll think about writing tests.
Overload development
We all want to write high-quality code, write features that have an impact on the end user, and write maintainable software. But sometimes developers try to create solutions that go far beyond what is required. Trying to solve problems that might not even happen. Jumping straight into a microservices architecture without knowing the boundaries of the system or whether multiple services are needed, thinking about scaling even before you get your first customer, trying to make everything configurable, thinking about performance optimization even before you see signs of delay, and so on.
Whenever you get into a situation like this, always follow the YAGNI and KISS principles. It basically means that you should keep things simple, build things up gradually, and if you think nothing is needed, just skip it.
Lone ranger
School teaches us to cooperate. Many sports teach us why it is important to be a team player. In a team, you think about others, you consult others before you decide on an approach, you give advice to your teammates.
Some developers only like to code on headphones with noise cancellations. They don’t want to interact with you and aren’t interested in what you’re doing. They are very efficient at coding and getting things done. But they are also bad at communicating and explaining their work to others.
The document
Some people think that as a developer, code documentation is not part of what they do. Well, that’s not true. Documenting the code is just as important as writing the code. How would you feel if you bought a new TV but didn’t have the TV installed and the manual for proper operation? You’d instantly curse the company that makes the TV.
Writing code and writing documentation about code are two separate, very different things. A developer can be great at one thing and terrible at another. Generally it is. Writing documentation is boring when you don’t know how to do it. This is true for many developers who don’t like writing code because they don’t know how to do it. Learning to document goes a long way.
Do things on a file
Wang wu’s methods and functions are several pages long. This is beyond reproach. He never thought about decomposition, making methods easier to reuse by other classes or methods. There’s no indentation. There are no consistent coding conventions or styles. Global variables are written everywhere, and so on.
This is the most annoying thing for me personally. Writing code isn’t hard, but writing good code is. And most people don’t even try. The code you write says a lot about your personality. If you’re writing dumb code, you’re probably dumb in other ways, too. However, if you start taking small steps to write good code, it will become a habit and you will enjoy the process. It’s nice to look at well-written code.
Short-term investor
Eat ➞ sleep ➞ code ➞ deployment is the motto of many developers. They just want to write code. They don’t want to learn, they don’t want to try out some new framework/library, they have no interest in the area, they don’t care if the functionality they’re doing is actually being used by customers.
This is why so many developers get tired and bored. Sometimes it’s important to be selfish and learn from the tasks you’re given. Spend some time reading about the technology or field. Show some interest in understanding why customers don’t like certain features. Ask the product manager questions to understand upcoming tasks and features. Take extra steps and be proactive.
arbitrary
My way or route is their motto. They are very opinionated. Has an opinion about almost everything. It’s what they think and what you think. It’s their solution versus your solution. I bet there will be arguments. Somehow they keep coming back to some part of the code that you implemented. It makes them uncomfortable, even though it works, tests and looks great.
This person is a big productivity bottleneck and will be the first to crack under the pressure and start pointing fingers. This person is bad for the team, no matter how experienced/good a developer he/she is.
That’s not my style
They write code. They don’t write documentation. They don’t do graphic design. They don’t complete paperwork. If it’s not code, it’s someone else’s problem. They won’t do it, even with a deadline.
Java developers simply don’t do any non-Java work. They panic when they learn that something in the registry needs to change. They’re scared to enter something into the database. They will do anything to avoid stepping out of their comfort zone.
I know from personal experience that this phenomenon is common among new developers. This is exactly the kind of thing a new developer should avoid. Be ready to jump in. You only learn when you do things. Good developers have a tendency to explore slowly/steadily out of their comfort zone.
Final summary
Learning from the mistakes of others is a great way to grow. I hope this article has helped you recognize the things you should avoid and help you become a better developer by negating rather than adding new things.
We may not be able to change our talent ceiling, but we can try to change our talent ceiling to improve our average score.