Table des matières
La signification des commentaires
注释规范
Maison développement back-end Golang Quelle est la spécification de codage des commentaires du langage Go ?

Quelle est la spécification de codage des commentaires du langage Go ?

Dec 06, 2022 pm 07:10 PM
go golang go语言 注释

Spécifications de codage des annotations : 1. Tous les objets exportés doivent être annotés pour expliquer leur objectif ; les objets non exportés doivent être annotés en fonction de la situation. 2. Si l'objet est dénombrable et que la quantité n'est pas clairement spécifiée, utilisez toujours la forme singulière et le temps continu sinon, utilisez la forme plurielle ; 3. Les commentaires sur les packages, les fonctions, les méthodes et les types sont tous des phrases complètes. 4. Les premières lettres des commentaires de type phrase doivent être en majuscules ; les premières lettres des commentaires de type phrase doivent être en minuscules. 5. La longueur d'une seule ligne de commentaires ne peut pas dépasser 80 caractères.

Quelle est la spécification de codage des commentaires du langage Go ?

L'environnement d'exploitation de ce tutoriel : système Windows 7, GO version 1.18, ordinateur Dell G3.

La signification des commentaires

  • Les commentaires peuvent nous aider à bien terminer le travail documentaire, et des commentaires bien rédigés peuvent faciliter notre maintenance future. Le commentaire de bloc de

  • /**/ et le commentaire sur une seule ligne de // sont deux styles de commentaire afin d'unifier le style, tous sur une seule ligne. les commentaires de ligne sont utilisés dans notre projet. La qualité des annotations détermine la qualité des documents générés. /**/ 的块注释和 // 的单行注释两种注释风格, 在我们的项目中为了风格的统一,全部使用单行注释,注释的质量决定了生成的文档的质量。

注释规范

  • 所有导出对象都需要注释说明其用途;非导出对象根据情况进行注释。

  • 如果对象可数且无明确指定数量的情况下,一律使用单数形式和一般进行时描述;否则使用复数形式。

  • 包、函数、方法和类型的注释说明都是一个完整的句子。

  • 句子类型的注释首字母均需大写;短语类型的注释首字母需小写。

  • 注释的单行长度不能超过80个字符。

1、包级别

包级别的注释就是对包的介绍,只需在同个包的任一源文件中说明即可有效。【相关推荐:Go视频教程编程教学

  • 每个包都应该有一个包注释,一个位于 package 子句之前行注释

  • 包注释应该包含下面基本信息

// @Title  请填写文件名称(需要改)
// @Description  请填写文件描述(需要改)
// @Author  请填写自己的真是姓名(需要改)  ${DATE} ${TIME}
// @Update  请填写自己的真是姓名(需要改)  ${DATE} ${TIME}
package ${GO_PACKAGE_NAME}
Copier après la connexion

2、结构(接口)注释

每个自定义的结构体或者接口都应该有注释说明,该注释对结构进行简要介绍,放在结构体定义的前一行,格式为: 结构体名, 结构体说明。同时结构体内的每个成员变量都要有说明,该说明放在成员变量的后面(注意对齐),实例如下:

// User   用户对象,定义了用户的基础信息
type User struct{
    Username  string // 用户名
    Email     string // 邮箱
}
Copier après la connexion

3、函数(方法)注释

  • 每个函数,或者方法(结构体或者接口下的函数称为方法)都应该有注释说明

  • 函数的注释应该包括三个方面

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

4、代码逻辑注释

  • 每个代码块都要添加单行注释

  • 注视使用 TODO 开始 详细如下

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

}
Copier après la connexion

其它说明

  • 当某个部分等待完成时,可用 TODO: 开头的注释来提醒维护人员。

  • 当某个部分存在已知问题进行需要修复或改进时,可用 FIXME: 开头的注释来提醒维护人员。

  • 当需要特别说明某个问题时,可用 NOTE:

Spécifications d'annotation

Tous les objets exportés doivent être annotés pour expliquer leur objectif. Les objets non exportés sont annotés en fonction de la situation. 🎜🎜🎜🎜Si l'objet est dénombrable et que la quantité n'est pas clairement spécifiée, utilisez toujours la forme singulière et le temps continu sinon, utilisez la forme plurielle. 🎜🎜🎜🎜Les commentaires sur les packages, les fonctions, les méthodes et les types sont tous dans une phrase complète. 🎜🎜🎜🎜Les premières lettres des commentaires de type phrase doivent être en majuscules ; les premières lettres des commentaires de type phrase doivent être en minuscules. 🎜🎜🎜🎜La longueur d'une seule ligne de commentaires ne peut pas dépasser 80 caractères. 🎜🎜🎜🎜🎜1. Niveau du package 🎜🎜🎜 Les commentaires au niveau du package sont une introduction au package. Ils doivent seulement être indiqués dans n'importe quel fichier source du même package pour être efficaces. [Recommandations associées : Tutoriel vidéo Go🎜, Enseignement de la programmation🎜】🎜🎜🎜🎜Chaque package doit avoir un commentaire de package, un commentaire de ligne avant la clause du package🎜🎜🎜🎜 package L'annotation doit contient les informations de base suivantes🎜🎜🎜
  // 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)
Copier après la connexion
🎜🎜2.Annotation de la structure (interface)🎜🎜🎜Chaque structure ou interface personnalisée doit avoir une annotation. L'annotation présente brièvement la structure et est placée dans la définition de la structure. le format est : nom de la structure, description de la structure. En même temps, chaque variable membre de la structure doit avoir une description, qui est placée après la variable membre (faites attention à l'alignement). Les exemples sont les suivants : 🎜rrreee🎜🎜3 Commentaires sur la fonction (méthode) 🎜🎜🎜🎜. 🎜Chaque fonction ou méthode (les fonctions sous les structures ou les interfaces sont appelées méthodes) doit avoir des commentaires 🎜🎜🎜🎜 Les commentaires sur les fonctions doivent inclure trois aspects 🎜🎜🎜rrreee🎜🎜4 Commentaires sur la logique du code 🎜🎜🎜🎜🎜Chaque bloc de code Vous. doit ajouter un commentaire d'une seule ligne🎜🎜🎜🎜 Regardez l'utilisation de TODO Les détails sont les suivants🎜🎜🎜rrreee🎜🎜Autres instructions🎜🎜🎜🎜🎜Lorsqu'une certaine partie est en attente d'être complétée, vous pouvez utiliser des commentaires commençant par À FAIRE : Alerter le personnel de maintenance. 🎜🎜🎜🎜Lorsqu'une certaine pièce présente un problème connu qui doit être corrigé ou amélioré, vous pouvez utiliser un commentaire commençant par FIXME : pour alerter le responsable. 🎜🎜🎜🎜Lorsque vous avez besoin d'expliquer spécifiquement un problème, vous pouvez utiliser un commentaire commençant par REMARQUE : : 🎜🎜🎜rrreee🎜Pour plus de connaissances liées à la programmation, veuillez visiter : 🎜Introduction à la programmation🎜 ! ! 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Apr 02, 2025 pm 02:06 PM

La bibliothèque utilisée pour le fonctionnement du numéro de point flottante dans le langage go présente comment s'assurer que la précision est ...

Quel est le problème avec le fil de file d'attente dans GO's Crawler Colly? Quel est le problème avec le fil de file d'attente dans GO's Crawler Colly? Apr 02, 2025 pm 02:09 PM

Problème de threading de file d'attente dans Go Crawler Colly explore le problème de l'utilisation de la bibliothèque Crawler Crawler dans le langage Go, les développeurs rencontrent souvent des problèmes avec les threads et les files d'attente de demande. � ...

Dans Go, pourquoi les chaînes d'impression avec println et string () ont-elles des effets différents? Dans Go, pourquoi les chaînes d'impression avec println et string () ont-elles des effets différents? Apr 02, 2025 pm 02:03 PM

La différence entre l'impression de chaîne dans le langage go: la différence dans l'effet de l'utilisation de fonctions println et string () est en Go ...

Quelles bibliothèques de GO sont développées par de grandes entreprises ou fournies par des projets open source bien connus? Quelles bibliothèques de GO sont développées par de grandes entreprises ou fournies par des projets open source bien connus? Apr 02, 2025 pm 04:12 PM

Quelles bibliothèques de GO sont développées par de grandes entreprises ou des projets open source bien connus? Lors de la programmation en Go, les développeurs rencontrent souvent des besoins communs, ...

Comment résoudre le problème de conversion de type user_id lors de l'utilisation du flux redis pour implémenter les files d'attente de messages dans le langage Go? Comment résoudre le problème de conversion de type user_id lors de l'utilisation du flux redis pour implémenter les files d'attente de messages dans le langage Go? Apr 02, 2025 pm 04:54 PM

Le problème de l'utilisation de Redessstream pour implémenter les files d'attente de messages dans le langage GO consiste à utiliser le langage GO et redis ...

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Apr 02, 2025 pm 05:09 PM

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Lorsque vous utilisez Goland pour le développement du langage GO, de nombreux développeurs rencontreront des balises de structure personnalisées ...

Quelle est la différence entre la structure de définition des mots clés `var` et« type »dans le langage Go? Quelle est la différence entre la structure de définition des mots clés `var` et« type »dans le langage Go? Apr 02, 2025 pm 12:57 PM

Deux façons de définir les structures dans le langage GO: la différence entre les mots clés VAR et le type. Lorsque vous définissez des structures, GO Language voit souvent deux façons d'écrire différentes: d'abord ...

Comment résoudre le problème des contraintes de type de fonction générique de Golang en cours de suppression automatique dans VSCODE? Comment résoudre le problème des contraintes de type de fonction générique de Golang en cours de suppression automatique dans VSCODE? Apr 02, 2025 pm 02:15 PM

La suppression automatique des contraintes de type de fonction générique Golang dans les utilisateurs de VScode peut rencontrer un problème étrange lors de l'écriture de code Golang à l'aide de VScode. quand...

See all articles