AI 辅助阅读 | 阅读代码

AI 辅助 代码阅读 代码可视化 AI 工具 流程图生成
文章探讨了如何利用 AI 辅助阅读和理解他人编写的代码,特别是在接手离职同事代码时面临的挑战。传统方法耗时且低效,而 AI 工具可以显著提升效率。具体步骤包括:首先,使用 AI 生成代码注释,帮助理解代码功能;其次,基于注释生成流程图代码,使用 PlantUML 等工具将代码可视化;最后,将生成的流程图代码在 PlantUML 网站上可视化,直观展示代码逻辑。文章还提到,虽然可以直接让 AI 生成流程图,但先生成注释再绘制流程图的效果更佳。此外,AI 还可以建议最适合的图表类型,如类图等,以更好地呈现代码结构。通过 AI 辅助,阅读和理解代码变得更加高效和直观。
文章内容
思维导图
常见问题
社交分享

一般同事离职时,就会其它人补上,第一件要做的事情就是接手他写的代码

但阅读别人的代码,难不了心态爆炸,一看代码太长又繁琐,看不下去了

传统的方法不仅耗时长,而且效率低下,这时我想到了使用 AI 来辅助这一过程,简直太高效了,整个过程分三步走

一、AI 生成代码注释

同事的这段代码有 200 行,核心就是订单打包,比如 10 个订单聚类后生成 8 个包裹

聚类的细节太多,想着用 AI 提取并绘制流程图,更加直观

首先使用 AI 编程工具 Baidu Comate,解读这段代码

在函数代码上方,找到代码解释菜单

点击代码注释,将会打开百度 AI 助手聊天框,显示代码的解读

二、AI 生成流程图代码

代码可视化一般需要创建 UML 图,这样的工具有很多,从使用文本描述来生成 UML 图的角度,我选择的是 PlantUML

PlantUML 是一个强大的工具,用于快速创建多种类型的图表。这些图表广泛用于软件开发和文档编写中,以下是 PlantUML 支持的一些主要图表类型:

  1. 序列图(Sequence Diagram):用于展示对象之间交互的时间序列,常用于展示系统内部组件或对象之间的消息传递。
  2. 用例图(Use Case Diagram):描述系统的功能和外部用户(参与者)之间的交互。
  3. 类图(Class Diagram):展示系统中类的结构和类之间的关系,如继承、接口实现、依赖关系等。
  4. 活动图(Activity Diagram):类似于流程图,用于展示从一个活动到另一个活动的控制流。
  5. 组件图(Component Diagram):展示系统的组件如何组合在一起工作。
  6. 状态图(State Diagram):展示一个对象在其生命周期内经历的状态以及状态间的转移。
  7. 对象图(Object Diagram):类图的一个实例,显示了系统中对象之间的关系。
  8. 部署图(Deployment Diagram):展示系统的物理部署,包括硬件和软件的配置。
  9. 时序图(Timing Diagram):展示对象状态随时间的变化。
  10. 包图(Package Diagram):展示代码的包结构,有助于理解代码的模块化组织。
  11. 组织结构图(Wireframe Graphic Interface):用于描述图形用户界面的布局和元素。
  12. 甘特图(Gantt Diagram):用于项目管理中,展示项目的时间线和进度。

PlantUML 中的活动图就是流程图,左边是代码语法,右边是可视化图形

将步骤一种拿到的代码注释,询问 ChatGPT:请基于下面这段代码注释,生成 PlantUML 活动图代码

三、流程图可视化

将步骤二中生成的流程图代码,复制到 plantuml 可视化网站

网址: http://www.plantuml.com/plantuml

点击 Submit 按钮,就可以获取到图片了

看流程图就大概知道这段代码的含义了,AI 解读代码绘制流程图,真的很方便

四、总结

以上通过代码 -> 注释 -> 绘制流程图的方法是经过了三个步骤,实际上也可以直接让 AI 解读代码,获取到流程图,只需要两步就可以完成,但是效果可能不如先生成注释,再绘制流程图

毕竟代码生成注释,是通过专有代码大模型生成,相比 通用大模型 GPT 理解代码可能更加顺畅一些

最后分享一个小技巧:代码的可视化呈现方式有很多种,为什么必须是流程图,而不是其它类型的图,可以问 AI 这段代码生成什么图比较好,选择最优呈现方式可视化

比如基于上面的代码,我也可以生成类图

思维导图生成中,请稍候...

问题 1: 为什么阅读别人的代码会让人感到困难?
回答: 阅读别人的代码通常因为代码过长、逻辑复杂或缺乏注释,导致理解起来耗时且容易让人感到挫败。

问题 2: 如何使用 AI 辅助阅读代码?
回答: 可以通过 AI 工具生成代码注释、绘制流程图,甚至直接让 AI 解读代码,从而更高效地理解代码逻辑。

问题 3: 什么是 PlantUML,它有哪些用途?
回答: PlantUML 是一个用于快速创建多种类型图表(如序列图、用例图、类图等)的工具,广泛应用于软件开发和文档编写中。

问题 4: 如何通过 AI 生成代码的流程图?
回答: 首先使用 AI 工具生成代码注释,然后基于注释询问 AI(如 ChatGPT)生成 PlantUML 活动图代码,最后将代码复制到 PlantUML 可视化网站生成流程图。

问题 5: 为什么建议先生成注释再绘制流程图?
回答: 专有代码大模型生成的注释可能比通用大模型(如 GPT)更准确,因此先生成注释再绘制流程图的效果通常更好。

问题 6: 除了流程图,还可以用哪些图表来可视化代码?
回答: 除了流程图,还可以生成类图、序列图、用例图等,具体选择哪种图表可以根据代码的特点和 AI 的建议来决定。

问题 7: 使用 AI 辅助阅读代码的优势是什么?
回答: AI 辅助阅读代码可以大幅提高效率,减少理解代码的时间,同时通过可视化工具让代码逻辑更加直观易懂。

问题 8: 如何选择最优的代码可视化方式?
回答: 可以询问 AI 这段代码适合生成哪种类型的图表,根据 AI 的建议选择最优的可视化方式。

问题 9: 使用 AI 辅助阅读代码的步骤有哪些?
回答: 主要分为三步:使用 AI 生成代码注释、基于注释生成流程图代码、将代码复制到可视化工具中生成图表。

问题 10: 为什么代码可视化对理解代码有帮助?
回答: 代码可视化可以将复杂的逻辑转化为直观的图形,帮助开发者更快地理解代码的结构和功能。