2023-12-20 14:12
AI 辅助阅读 | 阅读代码
一般同事离职时,就会其它人补上,第一件要做的事情就是接手他写的代码但阅读别人的代码,难不了心态爆炸,一看代码太长又繁琐,看不下去了传统的方法不仅耗时长,而且效率低下,这时我想到了使用 AI 来辅助这一过程,简直太高效了,整个过程分三步走一、AI 生成代码注释同事的这段代码有 200 行,核心就是订单打包,比如 10 个订单聚类后生成 8 个包裹聚类的细节太多,想着用 AI 提取并绘制流程图,更加直观首先使用 AI 编程工具 Baidu Comate,解读这段代码在函数代码上方,找到代码解释菜单点击代码注释,将会打开百度 AI 助手聊天框,显示代码的解读二、AI 生成流程图代码代码可视化一般需要创建 UML 图,这样的工具有很多,从使用文本描述来生成 UML 图的角度,我选择的是 PlantUMLPlantUML 是一个强大的工具,用于快速创建多种类型的图表。这些图表广泛用于软件开发和文档编写中,以下是 PlantUML 支持的一些主要图表类型:序列图(Sequence Diagram):用于展示对象之间交互的时间序列,常用于展示系统内部组件或对象之间的消息传递。用例图(Use Case Diagram):描述系统的功能和外部用户(参与者)之间的交互。类图(Class Diagram):展示系统中类的结构和类之间的关系,如继承、接口实现、依赖关系等。活动图(Activity Diagram):类似于流程图,用于展示从一个活动到另一个活动的控制流。组件图(Component Diagram):展示系统的组件如何组合在一起工作。状态图(State Diagram):展示一个对象在其生命周期内经历的状态以及状态间的转移。对象图(Object Diagram):类图的一个实例,显示了系统中对象之间的关系。部署图(Deployment Diagram):展示系统的物理部署,包括硬件和软件的配置。时序图(Timing Diagram):展示对象状态随时间的变化。包图(Package Diagram):展示代码的包结构,有助于理解代码的模块化组织。组织结构图(Wireframe Graphic Interface):用于描述图形用户界面的布局和元素。甘特图(Gantt Diagram):用于项目管理中,展示项目的时间线和进度。PlantUML 中的活动图就是流程图,左边是代码语法,右边是可视化图形将步骤一种拿到的代码注释,询问 ChatGPT:请基于下面这段代码注释,生成 PlantUML 活动图代码三、流程图可视化将步骤二中生成的流程图代码,复制到 plantuml 可视化网站网址: http://www.plantuml.com/plantuml点击 Submit 按钮,就可以获取到图片了看流程图就大概知道这段代码的含义了,AI 解读代码绘制流程图,真的很方便四、总结以上通过代码 -> 注释 -> 绘制流程图的方法是经过了三个步骤,实际上也可以直接让 AI 解读代码,获取到流程图,只需要两步就可以完成,但是效果可能不如先生成注释,再绘制流程图毕竟代码生成注释,是通过专有代码大模型生成,相比 通用大模型 GPT 理解代码可能更加顺畅一些最后分享一个小技巧:代码的可视化呈现方式有很多种,为什么必须是流程图,而不是其它类型的图,可以问 AI 这段代码生成什么图比较好,选择最优呈现方式可视化比如基于上面的代码,我也可以生成类图