news 2026/5/1 10:04:45

《高质量 C++/C 编程指南》注释规范 + VS2022 模板

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
《高质量 C++/C 编程指南》注释规范 + VS2022 模板

本文简单整理了一下《高质量 C++/C 编程指南》注释规范,并非原创且作者在书中已明确准许引用

一、核心注释规则(原文引用 + 极简解读)

1. 位置要求

【规则 2-7-6】注释应与其描述的代码相近,放上方(长注)或右方(短注),不可放下方。

  • 解读:
  • ✅ 单行代码注释:简短注释放右侧(与代码隔 1-2 个空格),长注释放上方;
  • ❌ 禁止放代码下方(易被忽略,违背自上而下的阅读逻辑);
  • ✅ 示例:// 修改 int 变量 4 字节值(上方注释)*pi = 0; // 赋值为 0(右侧注释)

2. 内容要求

【规则 2-7-1】注释是 “提示” 而非 “解释”,准确简洁,无用则删。

  • 解读:
  • 无需注释显而易见的代码(如int n = 0;);
  • 需注释场景:复杂逻辑、特殊算法、边界条件、指针 / 内存操作等(如 char * 解引用修改单字节的大小端逻辑)。

3. 格式要求

【规则 2-7-5】单行用//,多行用/* ... */,风格统一。

  • 解读:
  • VS2022 兼容 C 语言下的//单行注释,推荐优先使用;
  • 注释内容避免冗余(如不写 “给 n 赋值”,可写 “初始化 int 变量为十六进制值”)。

4. 必加场景

【规则 2-7-2】每个源文件头部必须加注释,说明文件名称、功能、作者、创建日期、版本 / 修改记录。

  • 解读:
  • 示例(C 语言):
  • /** 文件名称:mem_modify.c
  • 功能描述:演示指针解引用修改不同字节长度的内存值
  • 作 者:XXX
  • 创建日期:2025-12-16**/

【规则 2-7-3】函数(尤其对外接口)必须加注释,说明功能、参数(输入 / 输出)、返回值、注意事项。

  • 解读:
  • 示例(C 语言):
  • // 功能:通过 char 指针修改 int 变量首字节
  • // 参数:pc - 指向 int 变量首字节的 char 指针;val - 要修改的单字节值
  • // 注意:基于 x86 小端架构,仅修改低地址字节
  • void modifyCharByte(char* pc, char val) { *pc = val; }

【规则 2-7-5】项目注释格式需统一:单行注释用//,多行注释用/* ... */;注释首字符大写。

  • 解读:
  • VS2022 兼容 C 语言下的//单行注释,推荐优先使用;注释内容避免冗余(如不写 “给 n 赋值”,可写 “初始化 int 变量为十六进制值”)。

二、VS2022 示例

1. 源文件头部注释模板(规则 2-7-2)

/* * 文件名称:xxx.c(替换为实际文件名,如mem_modify.c) * 功能描述:【简要说明文件核心功能,如:演示指针解引用修改int变量不同字节长度的值】 * 作 者:【你的姓名/昵称】 * 创建日期:【YYYY-MM-DD,如2025-12-16】 * 修改记录:【无修改则写“无”;有修改则写“YYYY-MM-DD - 姓名 - 修改内容”】 * 注意事项:【可选,如:基于x86/x64小端架构,char*解引用仅修改int变量低地址首字节】 */

2. 函数注释模板(规则 2-7-3)

// 功能:【核心作用,如:通过int指针修改变量全部4字节值】 // 参数:【输入/输出参数说明,无则写“无”;如:n - 待修改的int型变量(输入/输出)】 // 返回值:【如:int - 0表示执行成功】 // 注意事项:【可选,如:解引用会覆盖变量所有4字节内容】 int modifyIntAllByte(int* n, int val) { *n = val; return 0; }

3. 单行 / 代码块注释模板(规则 2-7-6、2-7-1、2-7-5)

#include <stdio.h> /* * 文件名称:mem_modify.c * 功能描述:演示int*和char*解引用修改int变量不同字节长度的效果 * 作 者:XXX * 创建日期:2025-12-16 * 修改记录:无 * 注意事项:VS2022 x86/x64环境下为小端序,char*指向int变量低地址首字节 */ // 功能:通过int指针修改变量全部4字节值 // 参数:无 // 返回值:int - 0表示执行成功 int main() { // 初始化4字节int变量,十六进制值:0x11223344(小端存储:0x44→0x33→0x22→0x11) int n = 0x11223344; int* pi = &n; // 定义指向int变量的指针(右侧简短注释) *pi = 0; // 解引用修改n的全部4字节为0(右侧注释说明操作) printf("n = 0x%x\n", n); // 强制输出0x前缀的十六进制值,预期结果:0x0 // 重新初始化变量,用于演示char*解引用效果 n = 0x11223344; char* pc = (char*)&n; // 强制转换为char*,仅指向n的首字节(低地址) *pc = 0; // 仅修改n的首字节为0,其余3字节保留,预期结果:0x11223300 printf("n = 0x%x\n", n); return 0; }

再次声明:并非原创、仅做引用,之所以选原创是因为

OK,还是经典结尾:

嗯,希望能够得到你的关注,希望我的内容能够给你带来帮助,希望有幸能够和你一起成长。

写这篇博客的时候,微风正穿过纱窗轻拂桌面,屏幕上的注释与代码在暖光里渐显清晰。东华执码明规范,万里书山觅匠心。我走到阳台拍下了一张宿舍对面的照片作为本文的封面。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 5:49:30

关系型数据库主流内容校验工具整理及介绍

主流校验工具对比工具原理优点缺点性能pt-table-checksum分块CRC32校验成熟、安全、自动分块慢、大表压力大⭐⭐MySQL Enterprise Checksum内置CHECKSUM TABLE原生、简单全表锁、无分块⭐gh-ost在线DDL时校验无触发器、可并行仅限迁移过程⭐⭐⭐⭐Percona Toolkit (新)增强版校…

作者头像 李华
网站建设 2026/5/1 6:47:37

TensorFlow镜像加速下载:使用清华源提升AI开发效率

TensorFlow镜像加速下载&#xff1a;使用清华源提升AI开发效率 在人工智能项目开发中&#xff0c;最让人沮丧的场景之一莫过于&#xff1a;刚搭建好开发环境&#xff0c;满怀期待地敲下 pip install tensorflow&#xff0c;结果命令行卡在“Collecting tensorflow”长达十几分…

作者头像 李华
网站建设 2026/4/30 21:00:25

USB设备ID数据库:厂商与设备型号对照表

USB设备ID数据库&#xff1a;厂商与设备型号对照表 在日常的系统维护、驱动开发或硬件调试中&#xff0c;你是否曾遇到过一个未知的USB设备插入后&#xff0c;系统只显示一串冰冷的VID:PID代码&#xff1f;面对046d:082d这样的标识&#xff0c;普通用户可能束手无策&#xff0c…

作者头像 李华
网站建设 2026/4/30 11:23:57

Java集合-Queue讲解

目录一、集合框架层次结构二、Collection集合1、Queue队列1. LinkedList 作为队列2. ArrayDeque 作为队列3. PriorityQueue 优先队列4.LinkedBlockingQueue - 最常用的阻塞队列5. ConcurrentLinkedQueue - 高并发非阻塞队列2、队列操作模式对比1.插入操作对比2.移除操作对比3.查…

作者头像 李华
网站建设 2026/5/1 8:00:50

AI不会淘汰产品经理,但不会AI的会!大模型学习指南(建议收藏)

文章强调AI时代已全面到来&#xff0c;产品经理必须拥抱AI避免被淘汰。作者建议向取得实际成果的人学习AI知识&#xff0c;而非纯理论。特别推荐参加人人都是产品经理大会&#xff0c;邀请了腾讯音乐、金山办公、字节跳动等有AI落地经验的产品经理分享实战经验。我不想给你们罗…

作者头像 李华