How your classes should be ? π
Think of a well-written newspaper article, You read it vertically.
At the top you expect a headline that will tell you what the story is about and allows you to decide whether it is
something you want to read. The first paragraph gives you a synopsis of the whole story.
As you continue down-ward, the details increase until you have all the dates, names, quotes, claims, and other
minutia.
We would like a source file to be like a newspaper article. π
The name should be simple but explanatory.
The name, by itself, should be sufficient to tell us whether we are in the right module or not.
The topmost parts of the source file should provide the high-level concepts and algorithms.
Detail should increase as we move downward, until at the end we find the lowest level functions and details in the source file.
A newspaper is composed of many articles; most are very small, Some are a bit larger, Very few contain as much text as a page can hold.
This makes the newspaper usable. If the newspaper were just one long story containing a disorganized agglomeration of facts, dates, and names, then we simply would not read it !
#CleanCode #NewsPaper #Metaphor
Think of a well-written newspaper article, You read it vertically.
At the top you expect a headline that will tell you what the story is about and allows you to decide whether it is
something you want to read. The first paragraph gives you a synopsis of the whole story.
As you continue down-ward, the details increase until you have all the dates, names, quotes, claims, and other
minutia.
We would like a source file to be like a newspaper article. π
The name should be simple but explanatory.
The name, by itself, should be sufficient to tell us whether we are in the right module or not.
The topmost parts of the source file should provide the high-level concepts and algorithms.
Detail should increase as we move downward, until at the end we find the lowest level functions and details in the source file.
A newspaper is composed of many articles; most are very small, Some are a bit larger, Very few contain as much text as a page can hold.
This makes the newspaper usable. If the newspaper were just one long story containing a disorganized agglomeration of facts, dates, and names, then we simply would not read it !
#CleanCode #NewsPaper #Metaphor
Variable Declarations π
Variables should be declared as close to their usage as possible, Because our functions are very short, local variables should appear a the top of each function .
#CleanCode #Variables
Variables should be declared as close to their usage as possible, Because our functions are very short, local variables should appear a the top of each function .
#CleanCode #Variables
Dependent Functions βοΈ
If one function calls another, they should be vertically close,
and the caller should be above the callee .
#CleanCode
If one function calls another, they should be vertically close,
and the caller should be above the callee .
#CleanCode
Try Catch Finally π
Try blocks are like transactions.
Your catch has to leave your program in a consistent state, no matter what happens in the try.
For this reason it is good practice to start with a try-catch-finally statement when you are writing code that could throw exceptions.
This helps you define what the user of that code should expect, no matter what goes wrong with the code that is executed in the try .
#CleanCode #Exceptions
Try blocks are like transactions.
Your catch has to leave your program in a consistent state, no matter what happens in the try.
For this reason it is good practice to start with a try-catch-finally statement when you are writing code that could throw exceptions.
This helps you define what the user of that code should expect, no matter what goes wrong with the code that is executed in the try .
#CleanCode #Exceptions
Don't Pass & Return Null β
Returning null from methods is bad, but passing null into methods is worse.
Unless you are working with an API which expects you to pass null, you should avoid passing null in
your code whenever possible.
#CleanCode #Exception #Null
Returning null from methods is bad, but passing null into methods is worse.
Unless you are working with an API which expects you to pass null, you should avoid passing null in
your code whenever possible.
#CleanCode #Exception #Null
π‘ Consider the following three laws before writing Unit Test :
1- You may not write production code until you have written a failing unit test.
2- You may not write more of a unit test than is sufficient to fail, and not com-piling is failing.
3- You may not write more production code than is sufficient to pass the currently failing test.
#CleanCode #UnitTest #TDD
1- You may not write production code until you have written a failing unit test.
2- You may not write more of a unit test than is sufficient to fail, and not com-piling is failing.
3- You may not write more production code than is sufficient to pass the currently failing test.
#CleanCode #UnitTest #TDD
β Any fool can write code that a computer can understand, Good programmers write code that humans can understand .β ππ»
βMartin Fowler
βMartin Fowler
Test code is just as important as production codeβοΈ
It is not a second-class citizen .
It requires thought, design, and care .
It must be kept as clean as production code .
#CleanCode #UnitTest
It is not a second-class citizen .
It requires thought, design, and care .
It must be kept as clean as production code .
#CleanCode #UnitTest
What makes a clean testβ
Three things : Readability, readability, and readability.
Read-ability is perhaps even more important in unit tests than it is in production code .
What makes tests readable β
The same thing that makes all code readable :
clarity, simplicity & density of expression .
#CleanCode #UnitTest
Three things : Readability, readability, and readability.
Read-ability is perhaps even more important in unit tests than it is in production code .
What makes tests readable β
The same thing that makes all code readable :
clarity, simplicity & density of expression .
#CleanCode #UnitTest
Class definition π
The name of a class should describe what responsibilities it does .
In fact, naming is probably the first way of helping determine class size.
If we cannot derive a concise name for a class, then itβs likely too large.
The more ambiguous the class name, the more likely it has too many responsibilities.
#CleanCode #Class
The name of a class should describe what responsibilities it does .
In fact, naming is probably the first way of helping determine class size.
If we cannot derive a concise name for a class, then itβs likely too large.
The more ambiguous the class name, the more likely it has too many responsibilities.
#CleanCode #Class
Classes Should Be Small βοΈ
The first rule of classes is that they should be small .
The second rule of classes is that they should be smaller than that .
Our immediate question is always βHow smallβ β
With functions we measured size by counting physical lines .
With classes we use a different measure .
We count responsibilities .
#Cleancode #Class
The first rule of classes is that they should be small .
The second rule of classes is that they should be smaller than that .
Our immediate question is always βHow smallβ β
With functions we measured size by counting physical lines .
With classes we use a different measure .
We count responsibilities .
#Cleancode #Class
Getting software to work and making software clean are two very different activities .π‘
Most of us have limited room in our heads, so we focus on getting our code to work more than organization and cleanliness.
The problem is that too many of us think that we are done once the program works. β
We fail to switch to the other concern of organization and cleanliness.
#Cleancode
Most of us have limited room in our heads, so we focus on getting our code to work more than organization and cleanliness.
The problem is that too many of us think that we are done once the program works. β
We fail to switch to the other concern of organization and cleanliness.
#Cleancode
Consistent Name Scheme π
Usually, Languages have their own naming conventions; For example, java uses camelCase.
Naming needs to stay consistent, otherwise, it will very difficult to find things inside the document .
There are two main ways to name things :
1.camelCase : which means that every word of the file name is capitalized except for the first one, for example: nameFilesConsistently
2.Underscores : in this case you write underscores between each word, for example:
name_files_consistently
#NamingConventions
Usually, Languages have their own naming conventions; For example, java uses camelCase.
Naming needs to stay consistent, otherwise, it will very difficult to find things inside the document .
There are two main ways to name things :
1.camelCase : which means that every word of the file name is capitalized except for the first one, for example: nameFilesConsistently
2.Underscores : in this case you write underscores between each word, for example:
name_files_consistently
#NamingConventions
When you can solve the same number of problems as your competitor, it is now down to coding skill and ... typing speed.
Try this typing test at https://10fastfingers.com and follow the instructions there on how to improve your typing skill.
You need to familiarize your ο¬ngers with the position of frequently used programming language characters, e.g :
braces {} or () or <>, semicolon β;β, single quote for βcharβ and double quotes for βstringβ, ... .
#competitive_programming
Try this typing test at https://10fastfingers.com and follow the instructions there on how to improve your typing skill.
You need to familiarize your ο¬ngers with the position of frequently used programming language characters, e.g :
braces {} or () or <>, semicolon β;β, single quote for βcharβ and double quotes for βstringβ, ... .
#competitive_programming
10Fastfingers
10FastFingers.com - Typing Test, Competitions, Practice & Typing Games
10FastFingers - Improve your Typing Speed with our Typing Games
Avoid Writing Long Code Lines β
Writing long lines of code makes it very difficult to read, moving back and forth horizontally, losing any sense of what itβs actually written.
Style and indentation will help with this .π‘
Keep also in mind,
the terminal window limits characters to 80 per line, so if the code is longer, it will be just cut, making it incomprehensible.
#CleanCode
@ProgrammingTip
Writing long lines of code makes it very difficult to read, moving back and forth horizontally, losing any sense of what itβs actually written.
Style and indentation will help with this .π‘
Keep also in mind,
the terminal window limits characters to 80 per line, so if the code is longer, it will be just cut, making it incomprehensible.
#CleanCode
@ProgrammingTip