0

0

如何使用Doxygen为c++代码自动生成文档【项目规范】

穿越時空

穿越時空

发布时间:2026-01-06 16:05:50

|

756人浏览过

|

来源于php中文网

原创

Doxygen 是 C++ 项目最主流的文档生成工具,需正确编写注释、配置 Doxyfile 并同步更新。1. 安装后运行 doxygen -g 生成配置,doxygen 执行构建;2. 使用 /// 或 /** 注释,配合 @brief、@param 等标签;3. 配置 PROJECT_NAME、INPUT、EXTRACT_ALL 等关键项;4. 将 Doxyfile 纳入版本控制,集成到 CI 和开发流程中。

如何使用doxygen为c++代码自动生成文档【项目规范】

Doxygen 是 C++ 项目最主流的文档生成工具,它能从源码注释中自动提取结构化文档(HTML、PDF、XML 等),关键在于写对注释格式、配好配置、保持代码与文档同步。

1. 安装与基础配置

在 Ubuntu/Debian 上执行 sudo apt install doxygen doxygen-latexmacOS 用户可用 brew install doxygen;Windows 推荐下载官方安装包。安装后进入项目根目录,运行:

  • doxygen -g Doxyfile:生成默认配置文件
  • doxygen Doxyfile:按配置生成文档(输出在 html/latex/ 目录)

建议将 Doxyfile 提交到版本库,并在 CI 中加入 doxygen 步骤,确保每次 PR 都能检查文档完整性。

2. 注释规范:让 Doxygen “看得懂”

Doxygen 不解析普通注释,只识别以 /**////*! 开头的特殊注释块。推荐统一用 ///(简洁)或 /**(支持多行+富文本)。

立即学习C++免费学习笔记(深入)”;

GentleAI
GentleAI

GentleAI是一个高效的AI工作平台,为普通人提供智能计算、简单易用的界面和专业技术支持。让人工智能服务每一个人。

下载
  • 类/结构体:在 classstruct 关键字前写完整说明,可用 @brief 分离简述和详述
  • 函数:在声明前注释,用 @param 描述每个参数,@return 说明返回值,@throw 标明异常
  • 成员变量:简单说明用途即可,如 /// 毫秒级时间戳,自 Unix 纪元起

示例:

/// @brief 计算两点间欧氏距离
/// @param p1 第一个点(x, y)
/// @param p2 第二个点(x, y)
/// @return 距离值,非负浮点数
double euclidean_distance(const Point& p1, const Point& p2);

3. 配置文件关键项调优

打开 Doxyfile,重点修改以下字段(大小写敏感):

  • PROJECT_NAME = "MyCppLib":项目名,显示在首页标题
  • PROJECT_NUMBER = "v1.2.0":版本号,建议与 git tag 同步
  • INPUT = ./src ./include:指定源码路径(支持通配符,如 ./src/*.h *.cpp
  • RECURSIVE = YES:递归扫描子目录
  • EXTRACT_ALL = NO:设为 NO 可避免未注释符号出现在文档中(更严谨)
  • GENERATE_HTML = YESGENERATE_LATEX = NO:按需开关输出格式
  • QUIET = YES:减少构建日志干扰 CI 输出

4. 集成进开发流程

文档不是“一次性任务”,而是代码的一部分:

  • .gitignore 中排除 html/latex/xml/ 等生成目录,只保留 Doxyfile
  • MakefileCMakeLists.txt 中添加 docs 目标,例如:make docs 执行 doxygen Doxyfile
  • PR 模板中加入检查项:“新增/修改的公共接口是否已补充 Doxygen 注释?”
  • 配合 clang-format 和 cpplint,把文档质量纳入静态检查环节

不复杂但容易忽略:每次重构接口时,顺手更新对应注释——这是维持文档可信度的核心习惯。

相关专题

更多
html版权符号
html版权符号

html版权符号是“©”,可以在html源文件中直接输入或者从word中复制粘贴过来,php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

603

2023.06.14

html在线编辑器
html在线编辑器

html在线编辑器是用于在线编辑的工具,编辑的内容是基于HTML的文档。它经常被应用于留言板留言、论坛发贴、Blog编写日志或等需要用户输入普通HTML的地方,是Web应用的常用模块之一。php中文网为大家带来了html在线编辑器的相关教程、以及相关文章等内容,供大家免费下载使用。

643

2023.06.21

html网页制作
html网页制作

html网页制作是指使用超文本标记语言来设计和创建网页的过程,html是一种标记语言,它使用标记来描述文档结构和语义,并定义了网页中的各种元素和内容的呈现方式。本专题为大家提供html网页制作的相关的文章、下载、课程内容,供大家免费下载体验。

465

2023.07.31

html空格
html空格

html空格是一种用于在网页中添加间隔和对齐文本的特殊字符,被用于在网页中插入额外的空间,以改变元素之间的排列和对齐方式。本专题为大家提供html空格的相关的文章、下载、课程内容,供大家免费下载体验。

245

2023.08.01

html是什么
html是什么

HTML是一种标准标记语言,用于创建和呈现网页的结构和内容,是互联网发展的基石,为网页开发提供了丰富的功能和灵活性。本专题为大家提供html相关的各种文章、以及下载和课程。

2872

2023.08.11

html字体大小怎么设置
html字体大小怎么设置

在网页设计中,字体大小的选择是至关重要的。合理的字体大小不仅可以提升网页的可读性,还能够影响用户对网页整体布局的感知。php中文网将介绍一些常用的方法和技巧,帮助您在HTML中设置合适的字体大小。

503

2023.08.11

html转txt
html转txt

html转txt的方法有使用文本编辑器、使用在线转换工具和使用Python编程。本专题为大家提供html转txt相关的文章、下载、课程内容,供大家免费下载体验。

308

2023.08.31

html文本框代码怎么写
html文本框代码怎么写

html文本框代码:1、单行文本框【<input type="text" style="height:..;width:..;" />】;2、多行文本框【textarea style=";height:;"></textare】。

422

2023.09.01

PPT动态图表制作教程大全
PPT动态图表制作教程大全

本专题整合了PPT动态图表制作相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.07

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.8万人学习

AngularJS教程
AngularJS教程

共24课时 | 2.4万人学习

CSS教程
CSS教程

共754课时 | 18.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号