程序代码分析工具

文章目录

  • 工具简介和安装
    • Doxygen
    • Graphziv
    • 软件安装
  • 工具的运用
    • 启动和配置
    • 工具分析结果


工具简介和安装


Doxygen

Doxygen 是一种用于从 C 、C++ 、Objective-C 、C# 、Java 和 Python 等语言的源代码中生成文档的工具。它通过解析源代码中的注释来创建详细的 API 文档,包括类、函数、变量和模块的描述。

Doxygen 支持多种输出格式,如 HTML 、LaTeX 、RTF 和 XML,其主要的特点如下:

  • 支持多种编程语言:Doxygen 可以从多种编程语言的源代码中提取注释并生成文档;

  • 自动生成目录:Doxygen 可以根据源代码中的结构自动生成目录,方便用户查找和浏览文档;

  • 支持多种注释风格:Doxygen可以识别并处理多种注释风格,如 Javadoc 、Qt 和 Doxygen 风格的注释;

  • 支持图表和示例代码:Doxygen 可以从源代码中提取类图、继承关系图和协作图,并在文档中展示;

  • 可定制性强:Doxygen 提供了许多配置选项,用户可以根据需要定制输出的文档样式和内容。

  • 支持多语言:Doxygen 支持将文档翻译成多种语言,方便不同语言的用户阅读。


Graphziv

Graphviz(Graph Visualization Software)是一个开源的图形可视化软件,用于绘制 DOT 语言脚本描述的图形。它主要用于生成结构化信息的图形表示,如流程图、组织结构图、网络拓扑图等。

Graphviz 具有高度的可扩展性和灵活性,支持多种输出格式,如 PDF 、PNG 、SVG 和 HTML 等,其主要的组件如下:

  • DOT :一种描述图形的语言,用于定义节点、边和属性等图形元素;

  • dot :一个命令行工具,用于将 DOT 脚本转换为 PDF 、PNG 等格式;

  • Graphviz 库:一组用于创建、解析和渲染 DOT 脚本的 API ,支持 C、 Python 等多种编程语言。


软件安装

  • 在线方式

(1)Linux 操作系统中可以在终端中安装 Doxygen 和 Graphziv 软件,依次执行以下命令:

apt install doxygen doxygen-gui
apt install graphviz
  • 离线方式

(2)在 Doxygen 和 Graphziv 官网中下载对应版本的软件,安装方法参考官网即可,如下图所示。

  • Doxygen

Doxygen 官网

  • Graphviz

Graphviz 官网

(3)安装成功后,在终端执行以下命令查看软件版本信息,如下图所示。

doxygen -V
dot -V

版本信息


工具的运用

启动和配置

(1)Doxywizard 是配置和运行 Doxygen 的 GUI 前端,可以快捷地创建配置文件,在终端中执行以下命令启动该程序。

doxywizard

(2)设置 Step1Step2 中的 ”Wizard“ 选项卡,如下图所示。

  • Step1 中选择 Doxygen 的工作目录;

  • 设置 Doxygen 的项目名称;

  • 选择待分析的程序源代码文件或目录,可以是单个源码文件或源码目录;

  • 选择 Scan recursively ,递归分析源代码目录中的子目录内的源代码;

  • 设置生成文档的输出路径。

(3)设置 “Wizard” 选项卡的其它 topics ,如下图所示。

  • 在 “Mode” 中设置指定语言

Mode

  • 在 “Output” 中设置输出文档类型

Output

  • 在 “Diagrams” 中选择生成图类型

Diagrams

(4)设置 “Expert” 选项卡,如下图所示。

  • 取消勾选 FULL_PATH_NAMES

Expert

  • 在 “Build” 中设置 EXTPACT

Build

  • 在 “Input” 中排除文件或目录

Input

  • 在 “Dot” 中配置 Graphviz 的安装路径(Linux 默认路径为 /usr/bin

Dot

(5)在 “Run” 选择卡中点击 “Run doxygen” 开始分析源代码,完成后点击 “show HTML output” 会自动打开生成的文档网页,如下图所示。
run


工具分析结果

以 Linux 操作系统的 linux-0.11 内核源代码为例,展示 Doxygen 和 Graphviz 软件分析源码的部分结果,如下图所示。

  • 源码目录

linux

  • mian.c

main.c

  • task_struct 结构体

task_struct

  • 结构体索引

结构体


参考链接:

  • Doxygen 官网
  • Graphviz 官网

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/792110.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

码农失业倒计时?全球首个大厂AI程序员来了

进入互联网时代,程序员作为高收入职业的代表,长久以来一直是众多求职者梦寐以求的工作方向。程序员们凭借其对计算机科学的深刻理解和技术创新能力,不仅推动了科技的进步,也为自己赢得了可观的经济回报。 然而,随着人…

多叉树题目:N 叉树的层序遍历

文章目录 题目标题和出处难度题目描述要求示例数据范围 解法思路和算法代码复杂度分析 题目 标题和出处 标题:N 叉树的层序遍历 出处:429. N 叉树的层序遍历 难度 4 级 题目描述 要求 给定一个 N 叉树的根结点 root \texttt{root} root&#xf…

SAP FI学习笔记04 - 基础知识 - 新规会计科目,用 应收账款科目 做个例子

上一章讲了 应付账款 的来源及操作。 SAP FI学习笔记03 - 应付账款-CSDN博客 本章先尝试做一个会计科目,然后再用 应收账款 科目做个例子。 应收账款 和 应付账款 一样,也有两个视图。 1,新建几个会计科目 这一章来尝试着创建会计科目。 …

蓝桥杯嵌入式备考笔记

keil配置 LED-KEY-LCD 留下这几个 按键 创建俩个文件写代码,记得把这两个文件加进工程 led uwTick 1ms执行一次 写错了 不是1000 是100 PD2 SET 表示打开锁存器 可以操作LED LED对应PC引脚拉高是熄灭 key 如果要在main使用需要extern LCD最多21位 …

通讯录(顺序表)保存数据

在通讯录的基础上加上三个函数实现数据的保存。 分别为录入数据,加入数据与保存数据。 加入数据 先检查通讯录空间是否足够,然后将结构体ab中的数据全部放入通讯录mn中。 注意:字符串的拷贝要使用函数strcpy而不能直接用 加入完成之后将通…

深入浅出 -- 系统架构之微服务架构

1.1 微服务的架构特征: 单一职责:微服务拆分粒度更小,每一个服务都对应唯一的业务能力,做到单一职责 自治:团队独立、技术独立、数据独立,独立部署和交付 面向服务:服务提供统一标准的接口&…

Java数据结构-队列

目录 1. 队列概念2. 模拟实现队列2.1 链式队列2.2 循环队列 3. 双端队列4. 队列的应用4.1 用队列实现栈4.2 用栈实现队列 1. 队列概念 队列是一种只能在一端进行插入数据操作,另一端进行删除数据操作的数据结构,插入数据的叫队尾,删除数据的…

若依框架mysql 搜索中文等于不生效

背景&#xff0c;字段存储的是中文 不生效代码如下 <if test"constellation ! null and constellation ! ">AND u.constellation #{constellation}</if> 正确生效的代码如下 <if test"constellation ! null and constellation ! ">A…

Python搭建编程环境-安装Python3解释器

✅作者简介&#xff1a;CSDN内容合伙人、新星计划第三季Python赛道Top1&#x1f3c5; &#x1f525;本文已收录于Python系列专栏&#xff1a;零基础学Python &#x1f4ac;订阅专栏后可私信博主进入Python学习交流群&#xff0c;进群可领取Python视频教程以及Python相关电子书…

复现k8s黄金票据学习

1.什么是黄金票据 在 Kubernetes 中&#xff0c;"黄金票据"并不是一个常见的术语。可能你想了解的是服务账户&#xff08;Service Account&#xff09;。服务账户是 Kubernetes 中用于身份验证和授权的一种机制。它们允许 Pods 或其他工作负载在 Kubernetes 集群中与…

PAC的架构细节

PAC的架构细节&#xff1f;硬件原理&#xff1f;PAC如何生成&#xff1f;如何检查&#xff1f;指令集&#xff1f;本博客探讨这些问题。

Java集合(个人整理笔记)

目录 1. 常见的集合有哪些&#xff1f; 2. 线程安全的集合有哪些&#xff1f;线程不安全的呢&#xff1f; 3. Arraylist与 LinkedList 异同点&#xff1f; 4. ArrayList 与 Vector 区别&#xff1f; 5. Array 和 ArrayList 有什么区别&#xff1f;什么时候该应 Array而不是…

Prometheus+grafana环境搭建方法及流程两种方式(docker和源码包)(一)

1.选型对比 最近项目上有对项目服务及中间件的监控需求&#xff0c;要做实现方案调研&#xff0c;总结一下自己的成果&#xff0c;目前业界主流可选的方案有&#xff1a; 国外开源&#xff1a; Prometheus&#xff1a;Prometheus - Monitoring system & time series dat…

前端订阅后端推送WebSocket定时任务

0.需求 后端定时向前端看板推送数据&#xff0c;每10秒或者30秒推送一次。 1.前言知识 HTTP协议是一个应用层协议&#xff0c;它的特点是无状态、无连接和单向的。在HTTP协议中&#xff0c;客户端发起请求&#xff0c;服务器则对请求进行响应。这种请求-响应的模式意味着服务器…

【史上最细教程】 Typora+PicGo+Gitee 实现发给别人的Typora笔记也能看到图片

文章目录 问题描述前提准备&#xff1a;操作步骤&#xff1a;1.Gitee新建项目作为图床、获取仓库访问密钥2.PicGo连接Gitee图床3.Typora连接PicGo 问题描述 Typora记录的笔记&#xff0c;图片保存默认在本地&#xff0c;这时候复制出来上传CSDN、或发给别人的时候图片就是空链…

HCIP实验--5

实验要求&#xff1a; 实现过程&#xff1a; &#xff08;一&#xff09;配置IP地址&#xff1a; AR1: [AR1]int g0/0/0 [AR1-GigabitEthernet0/0/0]ip add 200.1.1.1 24 Apr 3 2024 19:25:38-08:00 AR1 %%01IFNET/4/LINK_STATE(l)[0]:The line protocol IP on the interf…

C++基础13:C++输入输出

此专栏为移动机器人知识体系下的编程语言中的 C {\rm C} C从入门到深入的专栏&#xff0c;参考书籍&#xff1a;《深入浅出 C {\rm C} C》(马晓锐)和《从 C {\rm C} C到 C {\rm C} C精通面向对象编程》(曾凡锋等)。 12.C输入/输出 12.1 C流类 计算机的输入和输出是数据传送的过…

Vue.js---------Vue基础

能够说出Vue的概念和作用能够使用vue/cli脚手架工程化开发能够熟练Vue指令 一.vue基本概念 1.学习vue Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态&#xff0c;并以相应的规则保证状态以一种可预测的方式发生变化。 渐进…

间接调制和带通采样!!(非奈奎斯特采样定理)

1. 直接变频 前面讲解数字调制原理时&#xff0c;直接利用IQ调制将基带信号变换为频带信号&#xff0c;这种频率变换一般被称为直接上变频&#xff1b;解调时&#xff0c;直接利用IQ解调&#xff0c;将频带信号变换回基带信号&#xff0c;这种频率变换一般被称为直接下变频。直…

vue 使用自定义标签URL Protocol 调用本地exe 并传参

创建注册表文件reg&#xff0c;并运行 里面的路径需要替换成实际exe的绝对路径 Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\App] "URL:App Protocol Handler" "URL Protocol""" [HKEY_CLASSES_ROOT\App\DefaultIcon] &qu…