Table of Contents
The meaning of comments
Comment specifications
Home Backend Development Golang What is the comment coding specification of go language?

What is the comment coding specification of go language?

Dec 06, 2022 pm 07:10 PM
go golang go language Comment

Comment encoding specifications: 1. All exported objects need to be commented to explain their purpose; non-exported objects need to be commented according to the situation. 2. If the object is countable and the quantity is not clearly specified, always use the singular form and the continuous continuous tense; otherwise, use the plural form. 3. The comments for packages, functions, methods and types are all in a complete sentence. 4. The first letters of sentence type comments must be capitalized; the first letters of phrase type comments must be lowercase. 5. The length of a single line of comments cannot exceed 80 characters.

What is the comment coding specification of go language?

The operating environment of this tutorial: Windows 7 system, GO version 1.18, Dell G3 computer.

The meaning of comments

  • Comments can help us complete the document work well. Well-written comments can facilitate our future maintenance. . There are two comment styles: block comments of

  • /**/ and single-line comments of //. In our project, for the sake of style Unified, all single-line comments are used, and the quality of the comments determines the quality of the generated documents.

Comment specifications

  • All exported objects need to be commented to explain their purpose; non-exported objects are commented according to the situation.

  • If the object is countable and the quantity is not explicitly specified, always use the singular form and the continuous continuous tense description; otherwise, use the plural form.

  • Comments for packages, functions, methods, and types are all complete sentences.

  • The first letters of sentence type comments must be capitalized; the first letters of phrase type comments must be lowercase.

  • The length of a single line of comments cannot exceed 80 characters.

1. Package level

Package-level comments are an introduction to the package and only need to be included in any source file of the same package. Description is valid. [Related recommendations: Go video tutorial, Programming teaching]

  • Each package should have a package comment, one in the package clause The previous line comment

  • package comment should contain the following basic information

// @Title  请填写文件名称(需要改)
// @Description  请填写文件描述(需要改)
// @Author  请填写自己的真是姓名(需要改)  ${DATE} ${TIME}
// @Update  请填写自己的真是姓名(需要改)  ${DATE} ${TIME}
package ${GO_PACKAGE_NAME}
Copy after login

2. Structure (interface) comment

Each custom structure or interface should have a comment. The comment briefly introduces the structure and is placed on the line before the structure definition. The format is: structure name, structure description. At the same time, each member variable in the structure must have a description. The description is placed after the member variable (pay attention to alignment). The example is as follows:

// User   用户对象,定义了用户的基础信息
type User struct{
    Username  string // 用户名
    Email     string // 邮箱
}
Copy after login

3. Function (method) comment

  • Each function or method (the function under the structure or interface is called a method) should have a comment

  • The comment of the function should Including three aspects

// @title    函数名称
// @description   函数的详细描述
// @auth      作者             时间(2019/6/18   10:57 )
// @param     输入参数名        参数类型         "解释"
// @return    返回参数名        参数类型         "解释"
Copy after login

4. Code logic comments

  • A single line comment must be added to each code block

  • Watch and use TODO. The details are as follows

// TODO  代码块的执行解释
if   userAge < 18 {

}
Copy after login

Other instructions

  • When a certain part is waiting to be completed, a comment starting with TODO: can be used to remind the maintainer.

  • When a certain part has a known problem that needs to be fixed or improved, you can use a comment starting with FIXME: to alert the maintainer.

  • When you need to explain a problem in particular, you can use a comment starting with NOTE::

  // NOTE: os.Chmod and os.Chtimes don&#39;t recognize symbolic link,
  // which will lead "no such file or directory" error.
  return os.Symlink(target, dest)
Copy after login

More Programming For related knowledge, please visit: Introduction to Programming! !

The above is the detailed content of What is the comment coding specification of go language?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What libraries are used for floating point number operations in Go? What libraries are used for floating point number operations in Go? Apr 02, 2025 pm 02:06 PM

The library used for floating-point number operation in Go language introduces how to ensure the accuracy is...

What is the problem with Queue thread in Go's crawler Colly? What is the problem with Queue thread in Go's crawler Colly? Apr 02, 2025 pm 02:09 PM

Queue threading problem in Go crawler Colly explores the problem of using the Colly crawler library in Go language, developers often encounter problems with threads and request queues. �...

In Go, why does printing strings with Println and string() functions have different effects? In Go, why does printing strings with Println and string() functions have different effects? Apr 02, 2025 pm 02:03 PM

The difference between string printing in Go language: The difference in the effect of using Println and string() functions is in Go...

Which libraries in Go are developed by large companies or provided by well-known open source projects? Which libraries in Go are developed by large companies or provided by well-known open source projects? Apr 02, 2025 pm 04:12 PM

Which libraries in Go are developed by large companies or well-known open source projects? When programming in Go, developers often encounter some common needs, ...

How to solve the user_id type conversion problem when using Redis Stream to implement message queues in Go language? How to solve the user_id type conversion problem when using Redis Stream to implement message queues in Go language? Apr 02, 2025 pm 04:54 PM

The problem of using RedisStream to implement message queues in Go language is using Go language and Redis...

What should I do if the custom structure labels in GoLand are not displayed? What should I do if the custom structure labels in GoLand are not displayed? Apr 02, 2025 pm 05:09 PM

What should I do if the custom structure labels in GoLand are not displayed? When using GoLand for Go language development, many developers will encounter custom structure tags...

What is the difference between `var` and `type` keyword definition structure in Go language? What is the difference between `var` and `type` keyword definition structure in Go language? Apr 02, 2025 pm 12:57 PM

Two ways to define structures in Go language: the difference between var and type keywords. When defining structures, Go language often sees two different ways of writing: First...

How to solve the problem of Golang generic function type constraints being automatically deleted in VSCode? How to solve the problem of Golang generic function type constraints being automatically deleted in VSCode? Apr 02, 2025 pm 02:15 PM

Automatic deletion of Golang generic function type constraints in VSCode Users may encounter a strange problem when writing Golang code using VSCode. when...

See all articles