通义灵码使用技巧分享:如何用好注释以及跨文件索引

news/2025/1/9 11:22:35/文章来源:https://www.cnblogs.com/tongyilingma/p/18644646

通义灵码是JetBrains、VSCode、Visual Studio等集成开发环境(IDE)中嵌入的一款智能开发助手工具,旨在通过人工智能技术简化软件开发过程,提升开发效率。

欢迎关注通义灵码公众号,获取第一手资讯!

代码注释的运用

通过注释引导补全生成

在缺乏额外注释引导的情况下,模型只能基于当前代码的上下文,以及项目中引用和找到的相似代码来推测接下来可能要编写的内容。当模型的推测不准确时,可以通过增加代码的方式来引导模型实现所需的代码。

  1. 例如,在以下这段代码中,模型首先推测了一个 CHAT_CONTEXT 字段,然而并不是我们所期望的内容。

  1. 接下来,我们添加一行注释,以指示模型下一个字段为历史记录。随后,模型生成了符合预期的字段及其相应的数据填充代码。

使用描述生成方法

  1. 通过“编辑区的代码注释引导补全”或“使用通义灵码问答面板”,均可实现基于注释生成整个方法的目标。由于通义灵码的智能问答场景所使用的模型参数量通常大于代码补全模型的参数量,因此,对于这类场景,通常建议在问答面板中直接提出所需生成的问题描述。

  1. 如果对期望生成的语言或方法签名(包括方法名、参数类型、返回值类型)有特殊要求,请在提问时详细描述该方法签名。

跨文件索引的运用

及时保存文件并更新索引

  1. 通义灵码的跨文件索引是抑制代码幻觉的重要机制。通过自动识别当前上下文中所涉及的类型和方法定义,模型能够感知项目中其他文件的类型所包含的成员以及方法所具有的参数。

  2. 在首次打开新项目时,通义灵码将自动创建项目的文件索引。此后,每次保存文件时,将触发单个文件的增量索引更新。然而,由于集成开发环境(IDE)中的文件通常存在内存缓存,在刚刚编写完一个文件后切换到另一个文件时,可能因本地索引尚未更新而无法识别新增加或修改过的内容,仍然按照原有的类型结构进行推理。例如在某代码项目中,我们为 Pet 对象新增了一个 saleable 属性。

  1. 随后切换至另一个文件,尝试让大模型进行补全,但模型推理出的逻辑使用的是另一个不太相关的字段。

  1. 若要消除这种信息差异,建议在编辑完前一个文件后,主动按下文件保存键快捷键Ctrl+S,然后再继续编辑其他文件。这样生成的内容将能够正确引用到修改过的对象结构。

针对MyBatis场景的优化方案

除了 Java、Python、JavaScript 等主流编程语言项目的跨文件引用功能,通义灵码还支持在编写 MyBatis 的 XML 文件时自动识别 Mapper 对象所引用的表结构类型。例如,在编写如下的 insert 语句时,插件会利用当前项目中的 TexiOrder 类型信息,确保生成的每个字段都为正确的。

提示词的使用技巧

在提问中引用所选代码

在提问时,如果同时在代码编辑区选择了文本或代码段,所选择的内容将自动以 Markdown 引用格式附加到提问内容的末尾。因此,若在提示词中提及所选择的代码,应使用“如下代码”或“以下内容”,例如。

  • 正确的说法:请检查以下代码是否存在下标越界风险。
  • 错误的说法:请检查选中的代码是否存在下标越界风险。(模型并不知道选中的代码是什么)

在使用命令时,请附加相关信息。

通过在命令后追加更多的辅助信息,可以为问答提供更为丰富的上下文,从而获得更符合预期的回复。

通过多轮对话生成有效代码

在与大语言模型进行对话时,提供的上下文越丰富,生成的结果越能符合用户的预期。因此,用户可以在上一轮对话的基础上继续进行问答,从而增加后续提问的上下文信息,这样生成的结果能够更好地反映整个历史上下文。然而,上一轮的历史信息有时可能会造成干扰,此时用户需要适时清空上下文。

在上一轮的基础上,进一步进行深入追问。

为模型提供参考示例

当需要模型按照指定格式输出或遵循特定前置规则时,提供一个参考实例往往能取得更好的效果,而非仅用文字描述。例如,某一程序的运行结果文件可以使通义灵码整理成特定的 JSON 结构文档。首先,打开文件并全选问题内容,然后在问答区域进行提问。对比下述两种提示词,后者能够更稳定地输出预期的数据格式。

  • 提示词1:将测试报告整理为JSON格式,每个测试结果为一个JSON结构。用例名称应放置于name字段,成功与否应记录于success字段,运行耗时需在duration字段中体现(单位为毫秒),测试覆盖率则应放置在coverage字段。detail字段的值为一个JSON,包含每次用例的输入和输出,分别存放于input和output字段中。
  • 提示词2:将测试报告整理为JSON格式,具体格式参照输入报告。
…报告内容略…

应输出的数据如下。请根据此示例生成测试报告。

[{“name”: “超出有效页码范围时,应返回空列表并提示无更多数据”,“duration”: 3434,“coverage”: 80,“detail”: [{“input”: “…”,“output”: “…”}
]}
]

为模型设定身份

与单纯的提问相比,预先向模型提供身份信息能够有效提升生成结果的稳定性和准确性。以生成测试用例为例,首先打开接口文档文件,全面选取文件内容,然后在问答区域进行提问。对比下述两种提示词,后者能够生成质量更高且覆盖率更好的用例。

  • 提示词1:请根据以下接口文档生成相应的测试用例。
  • 提示词2:您是一位经验丰富的测试工程师,具备对细节的高度敏感性,并能够高效识别潜在问题及边界情况。请根据以下接口文档生成详尽的测试用例,以确保所有预期功能行为均得到验证。

更多内容,可以点击此处查看通义灵码最佳实践指南!

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

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

相关文章

年终总结的总结

1、要不要认真写 一般来说,年终总结基本都是公司要求写的,因此有部分人会排斥地认为这是形式主义,所以就到网上随便复制一篇来应付了事。 实际上,认真回顾并总结过去一年中成功的经验以及失败的教训,对个人来说是百利而无一害的,也是对自己人生负责任的表现。 毕竟,一年…

Java内存溢出分析

拿到堆快照,利用MAT工具进行分析 https://eclipse.dev/mat/download/参考 https://club.kdcloud.com/article/612243561462691840?productLineId=29&isKnowledge=2&lang=zh-CN

Qml 中实现毛玻璃效果

毛玻璃效果(Acrylic Effect)是一种常见的 UI 设计风格,它通过模糊背景并添加透明度和噪声效果,使界面元素看起来像是半透明的磨砂玻璃。 本文将介绍如何使用 Qml 实现这种效果,并提供一个完整的示例代码。【写在前面】 毛玻璃效果(Acrylic Effect)是一种常见的 UI 设计风…

VMware ESXi 8.0U3c macOS Unlocker OEM BIOS 标准版和厂商定制版,已适配主流品牌服务器

VMware ESXi 8.0U3c macOS Unlocker & OEM BIOS 标准版和厂商定制版,已适配主流品牌服务器VMware ESXi 8.0U3c macOS Unlocker & OEM BIOS 标准版和厂商定制版 ESXi 8.0U3c 标准版,Dell (戴尔)、HPE (慧与)、Lenovo (联想)、Inspur (浪潮)、Cisco (思科)、Hitachi (日…

0 编程经验的我,竟然用通义灵码完成了小程序的开发

通义灵码携手科技博主@玺哥超carry 打造全网第一个完整的、面向普通人的自然语言编程教程。完全使用 AI,再配合简单易懂的方法,只要你会打字,就能真正做出一个完整的应用。通义灵码携手科技博主@玺哥超carry 打造全网第一个完整的、面向普通人的自然语言编程教程。完全使用 …

ai编程助手cursor初步使用体验

一 前言 前面介绍了通义灵码等国内ai编程助手,这一篇写写国外的。 cursor是一款ai编程助手,因为他包含ChaGpt4和Claude3.5等先进的ai大模型来辅助编成。 同时它又是一个像vscode的代码编辑器,它基于VSCode修改而来,如果平常使用 VSCode 进行开发,那么可以非常便捷地迁移过…

SQL优化| IS NOT NULL 优化与 NOT NULL 查询慢优化

在SQL查询时,SQL语句中由于使用了 IS NOT NULL ,导致查询时间过长,数据表有180W条数据,查询的字段上已经有普通索引,我们使用简单的sql查询这个cfErpPayNumber 不是空的记录,耗时需要1843ms,这是非常头疼的, 查看执行计划,是全表扫描这里为了加快查询效率,我们需要加入…

【分布式存储】HDFS

https://hadoop.apache.org/docs/r1.0.4/cn/hdfs_design.htmlHDFS(Hadoop Distributed File System )Hadoop分布式文件系统。是根据google发表的论文翻版的。论文为GFS(Google File System)Google 文件系统 设计前提和目标: 硬件错误、 流式数据访问、 大规模数据集:运行…

QT程序监控不到拖拽事件如dragEnterEvent - Windows权限问题的解决方案

问题:当客户端已高完整性启动(例如启动客户端的进程是Bypass UAC启动的高完整性的进程,导致客户端继承了其高完整性),由于explorer.exe资源管理器是以中等Medium权限启动,客户端的权限较高,导致设置了qt编写的客户端设置了的setAcceptDrops(true)后依然无法触发dropEven…

Podman 安装 harbor

详细描述了在Debian系统上使用Podman部署Harbor的步骤。它包括安装Podman、创建专用网络、下载并加载Harbor镜像,接着依次部署Redis、PostgreSQL、Registry、Portal、JobService、Registryctl、Harbor核心服务和Nginx等组件,最后通过一系列命令检查部署状态并验证服务是否正常…

Linux 统计活跃线程和线程数

使用Linux命令ps -eT动态查看进程中,以指定字符串打头的活跃线程和线程数。摘要:使用Linux命令ps -eT动态查看进程中,以指定字符串打头的活跃线程和线程数。 动态查看进程的线程数及活跃线程数 实现方案在Linux系统中,可以使用以下命令来动态查看进程中名字包含“keyword”…