Code quality evaluation is highly subjective
The most commonly used evaluation criteria are maintainability, readability, extensibility, flexibility, simplicity, reusability and testability.
First, maintainability
Let’s start with a couple of concepts
Maintenance: refers to the work of modifying bugs, modifying the code, adding new code and so on;
Easy code maintenance: the ability to quickly modify or add code without breaking the original code design or introducing new bugs;
Code that is not maintainable: Changes or additions to code that run a significant risk of introducing new bugs and take a long time to complete.
We can give a more intuitive but more accurate feeling from the side.
If bugs are easy to fix, changes are easy to make, and features are easy to add, then we can assume that the code is maintainable to us.
Whether it is easy to maintain is for the maintenance of people, different levels of people for the same code maintenance ability is not the same, and the degree of familiarity with the system also accounts for a large subjective factor.
Ii. Readability
How do you evaluate the readability of a piece of code?
It is difficult to give a list that covers all the evaluation criteria, such as compliance with coding specifications, meaningful naming, detailed comments, appropriate length of functions, clarity of modules, compliance with high cohesion and low coupling, etc.
In fact, code review is a great way to check code readability. If your code can be easily read by others, your code is readable. If colleagues read your code and have a lot of questions, your code readability needs to improve.
Three, scalability
Add new functional code by extension without modifying or modifying the original code in small amounts.
To put it bluntly, the code reserves some function extension points, and you can plug new function code directly into the extension points, rather than having to add a function and make a lot of changes to the original code.
The open closed principle
Adding new functionality should be done by extending the existing code (adding modules, classes, methods, properties, etc.) rather than modifying the existing code (modifying modules, classes, methods, properties, etc.).
There are two things to note about this definition. The first point is that the open closed principle does not mean that changes are completely eliminated, but that new features can be developed with minimal changes to the code. Second, the same code change may be considered a “change” under coarse-code granularity. At a fine code granularity, it might be considered “extended.”
Iv. Flexibility
Flexibility is a very broad word, and features can be used in many scenarios. If a piece of code is easy to extend, reuse, or use, field code is considered flexible
Five, simplicity
The KISS principle: “Keep It Simple, Stupid”. Keep your code simple.
The KISS principle is an important means of keeping code readable and maintainable. The “simplicity” of the KISS principle is not measured in lines of code. Fewer lines of code does not necessarily mean simpler code; we need to consider logic complexity, implementation difficulty, code readability, and so on. Moreover, complex solutions to complex problems do not violate the KISS principle. In addition, the same code that satisfies the KISS principle in one business scenario may not satisfy it in another application scenario.
KISS principle
There are a few guidelines for writing code that satisfies the KISS principle:
- Don’t implement code using techniques your colleagues may not understand;
- Don’t reinvent the wheel, be good at using existing toollibraries;
- Don’t over-optimize.
Sixth, reusability
This can be simply interpreted as minimizing duplication of code.
Code reusability is closely related to the DRY (Don’t Repeat Yourself) design principle.
DRY principle
Three cases of code repetition: implementation logic repetition, functional semantic repetition, and code execution repetition.
- Code that implements logical duplication, but not functional semantics, does not violate the DRY principle.
- The DRY principle is also violated if you implement code that has the same logic but the same functional semantics.
- In addition, repeating code execution is a DRY violation.
There are seven ways to improve code reusability.
- Reduce code coupling
- Meet the single responsibility principle
- modular
- Separation of business and non-business logic
- Common code sink
- Inheritance, polymorphism, abstraction, encapsulation
- Apply design patterns such as templates
Seven, testability
The testability of the code is a very accurate reflection of the quality of the code from the side.
The code is not testable, it’s hard to write unit tests, and that’s basically a sign that the code is not designed properly.
1. What is testability of code?
Roughly speaking, testability of code is how easy it is to write unit tests against your code. If a piece of code is difficult to unit test, or if unit tests are laborious to write and rely on advanced features in the unit testing framework, it often means that the code is not well designed or testable.
2. The most effective way to write testability code
Dependency injection is the most effective way to write testability code. Dependency injection allows us to mock out external services when writing unit tests, which is one of the most technically challenging aspects of writing unit tests.
3. Common anti-patterns
There are five common types of test-unfriendly code:
- Code contains undecided behavior logic (undecided behavior logic is code whose output is random or uncertain, for example, code related to time or random numbers).
- Misuse of mutable global variables
- Abusing static methods
- Use complex inheritance relationships
- Highly coupled code