Curated from: medium.com
Ideas, facts & insights covering these topics:
23 ideas
·63.8K reads
307
10
Explore the World's Best Ideas
Join today and uncover 100+ curated journeys from 50+ topics. Unlock access to our mobile app with extensive features.
Writing quality programs is a process with a flow:
Think. Research. Plan. Write. Validate. Modify.
One of the biggest mistakes you can make as a beginner programmer is to start writing code right away without much thinking and researching. While this might work for a small stand-alone application, it has a big, negative effect on larger applications.
Just like you need to think before saying anything you might regret, you need to think before you code anything you might regret. Coding is also a way to communicate your thoughts.
808
5.94K reads
Do not look for a perfect plan before jumping into writing code.
Look for a good enough plan, something that you can use to get started. The truth is, your plan will change, but what it was good for is to force you into some structure that leads to more clarity in your code. Too much planning is simply a waste of your time.
704
4.9K reads
Never underestimate the importance of code quality. Look at coding as a way to communicate implementations. Your main job as a coder is to clearly communicate the implementations of any solutions that you are working on.
If you are not consistent with your indentation and capitalization, you should simply lose your license to code.
689
4.55K reads
Your job as a professional programmer is not to find a solution to the problem. It is to find the simplest solution to the problem.
Simple means the solution has to work correctly and perform adequately but still be simple enough to read, understand, and maintain.
698
4.2K reads
Don't be attached to code because of how much effort you put into it. Bad code needs to be discarded if it isn't working. If you're not happy with a solution, you'll be stuck with it.
When it comes to writing programs, the right mentality is to fail early and fail often. The minute you begin doubting a solution, you should consider throwing it away and re-thinking the problem.
704
3.79K reads
683
3.69K reads
The big idea here is that you want your code to have High Cohesion and Low Coupling, which is just a fancy term that means keep related code together (in a class) and reduce the dependencies between different classes.
690
3.79K reads
Do not write code that you do not need today. Do not plan for the unknown future. Writing a feature because you think that you might need it in the future is simply wrong.
Always write the minimum amount of code that you need today for the solution that you are implementing.
688
3.23K reads
The most common data structure mistake is probably the use of lists instead of maps to manage a list of records. Using lists for scalar values is okay and often the better choice for large collections.
Not using stacks when writing code that requires some form of Recursion, it is always tempting to use simple recursive functions. Using a stack structure is an alternative to using recursive functions, but it is usually hard to optimize recursive code.
683
2.9K reads
Here are a few wrong practices that usually make the code a bigger mess than what it was (not a complete list):
694
2.59K reads
Most comments can be replaced with Better-Named elements in your code. If you are tempted to write a what comment to clarify the code, please do not point out the obvious. Remove comments like these if you have to deal with them.
Educate programmers who write comments about how bad they are.
660
2.43K reads
If you think you are an expert programmer, you are a newbie. If you are not writing tests in code, you are most likely testing your program manually.
There is nothing wrong with manually testing your code. However, you should manually test your code to figure out how to automatically test it. If you successfully test an interaction with your application, you should go back to your code editor and write code to automatically perform the exact same interaction the next time you add more code to the project.
678
2.27K reads
If the author of that code is long gone or cannot remember it, research that code and try to understand everything about it.
Only when you completely understand the code you get to form an opinion whether it is bad or good. Do not assume anything before that.
658
2.13K reads
660
2.03K reads
The good rule to remember about this is: if you cannot measure the suspected performance problem with the code, do not attempt to optimize it.
If you are optimizing before executing the code, chances are you are doing it prematurely. There is also a big chance that the optimization you are investing your time in is completely unnecessary.
657
1.88K reads
Do not be that developer. Be one of the professional ones who put themselves in their end-users’ shoes. They imagine what the users of this particular feature need and how they might behave.
They think about the ways to make the feature easy for the users to find and use, not about the easy way to make the feature exist in the application somehow without any thoughts about that feature’s discoverability and usability.
667
1.75K reads
Everyone has their list of favorite tools to assist them in their programming-related activates. Some tools are great and some are bad but most tools are great for one particular thing and not so great for many others.
Relying on a tool’s popularity rather than how much it fits the problem is a sign of a true newbie.
657
1.66K reads
An important aspect of a program is often the management of some form of data. The program will be the interface to add new records, delete old ones, and modify others.
Even the smallest bugs in a program’s code will result in an unpredictable state for the data it manages. This is especially true if all validations on the data are done entirely through the same buggy program.
Beginners might not immediately connect the dots when it comes to code-data relationships.
654
1.61K reads
In programming, some wheels are simply worth reinventing. Programming is not a well-defined domain. So many things change so fast and new requirements are introduced faster than any team can handle.
However, if you need a wheel, do not buy a whole new car and put the car that you are maintaining on top of that new car. Do not include a whole library just to use a function or two out of it.
666
1.75K reads
Coding newbies often look at code reviews as criticism. Look at every code review as a learning opportunity.
You are a forever code Learner. You need to accept that.
665
1.92K reads
Source control is not about just pushing your changes for others to have and build on. It is a lot bigger than that. Source control is about clear history. Code will be questioned and the history of the progress of that code will help answer some of the tough questions. This is why we care about commit messages. They are yet another channel to communicate your implementations and using them with small commits help future maintainers of your code figure out how the code reached the state that it is in right now.
655
1.42K reads
Every variable we define represents a shared state. It holds data that can be changed by all elements in the same scope as that variable.
The more global the scope is, the worse the span of this shared state. Try to keep new states contained in small scopes and make sure they do not leak upward.
655
1.58K reads
You will often be in the zone and forget to take breaks.
Take a lot of short breaks. Leave your chair and take a short walk. Come back to the code with fresh eyes.
671
1.76K reads
IDEAS CURATED BY
Learn more about computerscience with this collection
Find out the challenges it poses
Learn about the potential impact on society
Understanding the concept of Metaverse
Related collections
Similar ideas
5 ideas
4 Mistakes I Made as a Programmer, but I Had To Become a CTO To See Them
betterprogramming.pub
4 ideas
9 ideas
A Beginner's Guide To Bitcoin
Matthew R. Kratter
Read & Learn
20x Faster
without
deepstash
with
deepstash
with
deepstash
Personalized microlearning
—
100+ Learning Journeys
—
Access to 200,000+ ideas
—
Access to the mobile app
—
Unlimited idea saving
—
—
Unlimited history
—
—
Unlimited listening to ideas
—
—
Downloading & offline access
—
—
Supercharge your mind with one idea per day
Enter your email and spend 1 minute every day to learn something new.
I agree to receive email updates