★★★★✰

An overview of the

Notes are not like Schindler’s List. They are not “unalloyed good”. In fact, comments are, at best, a necessary evil.

The authors do not recommend writing unnecessary comments, but only if you have to.

1. Comments don’t beautify bad code

“Don’t comment bad code, rewrite it.”

Priority with comments: Explain with code (no comments) > Use comments > Bad comments.

2. Good comments

Some comments are necessary and helpful.

1) Interpretation of intent

Describe your purpose for writing this code.

Sometimes, when you see comments like this, you may not agree with the solution the programmer has provided to the problem, but at least you know what he is trying to do.

2) interpretation

Sometimes, it is useful to translate obscure arguments or return values into an easy-to-understand form.

For example, the underscore. Js library has some method descriptions:

underscore.rest(useList) // Returns all elements in the array except the first element.
underscore.flatten(useList) [1,2,[3]] => [1,2,3]
Copy the code
3) warning

A description of a bug in some method call, or a reminder to close an open thread.

// Note: this method may consume some performance
traverse(list) {}
Copy the code
4) TODO comment

Sometimes, due to time or circumstances, some parts that need to be improved later can be marked with todo comments. But be sure to check off these notes on a regular basis. Do not use Later equals never

5) emphasize

Sometimes, it’s important to highlight why a piece of logic seems irrational, but why it’s being done anyway. In case the reader doesn’t understand, or is easily changed.

3. The bad comments

Which comments are particularly unnecessary?

1) Talk to yourself
try {
	doSmthing()
} catch() {
	// It is not clear how to handle this exception.
}
Copy the code
2) Redundant comments

Sometimes it takes longer to read extra comments than it does to read code.

// This is a traversal of the user list to find users whose names are more than 2 characters long and put them into collection A
let a = []
for (let i=0; i<userList.length; i++) {
	if (userList[i].name.length > 2) {
		a.push(userList[i])
	}
}
Copy the code
3) Misleading comments

Sometimes a more lethal action than not writing a comment at all is writing misleading comments. Not only does it not help, but it may even cause unnecessary trouble.

So make sure your annotations are accurate.

4) Rigid comments

The meaning of the method itself is clear; there is no need to add extra templates.

/* * @param title CD name * @param author CD author * @param publishDate CD release time * @param time CD length */
function addCD(title, author, publishDate, time)
Copy the code
5) Journaling comments

Sometimes, some students will write a log of changes as comments, like who changed the code and when.

These journaling comments are well documented in our modern code editors, so there’s no need to overwrite them.

6) Tagging comments

Sometimes, in order to facilitate the search, some students will use some marked comments, this kind of comments after temporary use, remember to delete, or more, the code will show messy ugly.

/ / here / / / / / / / / / / / / / / / / / / / / / / /
doSmthing() {}
Copy the code
7) Commented out code

Sometimes, students comment out code they don’t use. Others are afraid to delete it, thinking it must be there for a purpose. This approach also makes the program ugly.

If you’re worried about code that can’t be recovered, don’t worry; modern editors are pretty good at keeping track of changes.

doSmthing()
// for (let i=0; i<users.length; i++) {
//	if (a) {
// doAction()
//	}
// }
doSmthingElse()
Copy the code

This article is based on Code Cleanliness by Robert C. Martin, translated by Han Lei.

Zhejiang Dahua Technology Co., Ltd.- Soft research – Smart City Product R&D Department Recruiting senior front end, welcome to contact, interested can send resume to chen_zhen@dahuatech.com, long-term effective

Third, function

5. Format