Github Copilot Agent模式使用经验分享

Github Copilot Agent模式使用经验分享

本文总结了如何使用 GitHub Copilot Agent 模式,并分享实际操作经验。

前置设置

  1. 使用 VSCode Insider;
  2. 安装 GitHub Copilot(预览版)插件;
  3. 选择 Claude 3.7 Sonnet(预览版)模型,该模型在代码编写方面表现出色,同时其它模型在速度、多模态(如图像识别)及推理能力上具备优势;
  4. 工作模式选择 Agent。

操作步骤

  1. 打开 “Copilot Edits” 选项卡;
  2. 添加附件,如 “Codebase”、“Get Errors”、“Terminal Last Commands” 等;
  3. 添加 “Working Set” 文件,默认包含当前打开的文件,也可手动选择其他文件(如 “Open Editors”);
  4. 添加 “Instructions”,输入需要 Copilot Agent 特别注意的提示词;
  5. 点击 “Send” 按钮,开始对话,观察 Agent 的表现。

其它说明

  • VSCode 通过语言插件提供的 lint 功能可以产生 Error 或 Warning 提示,Agent 能自动根据这些提示修正代码。
  • 随着对话的深入,Agent 生成的代码修改可能会偏离预期。建议每次会话都聚焦一个明确的主题,避免对话过长;达到短期目标后结束当前会话,再启动新任务。
  • “Working Set” 下的 “Add Files” 提供 “Related Files” 选项,可推荐相关文件。
  • 注意控制单个代码文件的行数,以免 token 消耗过快。
  • 建议先生成基础代码,再编写测试用例,便于 Agent 根据测试结果调试和自我校验。
  • 为限制修改范围,可在 settings.json 中添加如下配置,只修改指定目录下的文件, 仅供参考:
"github.copilot.chat.codeGeneration.instructions":[{"text":"只需修改 ./script/ 目录下的文件,不修改其他目录下的文件."},{"text":"若目标代码文件行数超过 1000 行,建议将新增函数置于新文件中,通过引用调用;如产生的修改导致文件超长,可暂不严格遵守此规则."}],"github.copilot.chat.testGeneration.instructions":[{"text":"在现有单元测试文件中生成测试用例."},{"text":"代码修改后务必运行测试用例验证."}],

常见问题

输入需求得不到想要的业务代码

需要将大任务拆分成较小的任务, 每次会话只处理一个小任务. 这是由于大模型的上下文太多会导致注意力分散.

喂给单次对话的上下文, 需要自己揣摩, 太多和太少都会导致不理解需求.

DeepSeek 模型解决了注意力分散问题, 但需要在 cursor 中使用 Deepseek API. 不清楚其效果如何.

响应缓慢问题

需要理解 token 消耗机制, token 输入是便宜且耗时较短的, token 输出贵很多, 且明显更缓慢.

假如一个代码文件非常大, 实际需要修改的代码行只有三行, 但由于上下文多, 输出也多, 会导致 token 消耗很快, 且响应缓慢.

因此, 必须要考虑控制文件的大小, 不要写很大的文件和很大的函数. 及时拆分大文件, 大函数, 通过引用调用.

业务理解问题

理解问题或许有些依赖代码中的注释, 以及测试文件, 代码中补充足够的注释, 以及测试用例, 有助于 Copilot Agent 更好的理解业务.

Agent 自己生成的业务代码就有足够多的注释, 检视这些注释, 就可以快速判断 Agent 是否正确理解了需求.

生成大量代码需要 debug 较久

可以考虑在生成某个特性的基础代码后, 先生成测试用例, 再调整业务逻辑,这样 Agent 可以自行进行调试,自我验证.

Agent 会询问是否允许运行测试命令, 运行完成后会自行读终端输出, 以此来判断代码是否正确. 如果不正确, 会根据报错信息进行修改. 循环往复, 直到测试通过.

也就是需要自己更多理解业务, 需要手动写的时候并不太多, 如果测试用例代码和业务代码都不正确, Agent 既不能根据业务写出正确用例, 也不能根据用例写出正确业务代码, 这种情况才会出现 debug 较久的情况.

总结

理解大模型的 token 消耗机制, 输入的上下文很便宜,输出的代码较贵,文件中未修改的代码部分可能也算作输出, 证据是很多无需修改的代码也会缓慢输出.

因此应尽量控制单文件的大小, 可以在使用中感受 Agent 在处理大文件和小文件时, 响应速度上的差异, 这个差异是非常明显的.

Read more

2025年必备!5款免费AIGC检测工具推荐,论文查重一键搞定

2025年必备!5款免费AIGC检测工具推荐,论文查重一键搞定

人工智能技术正以迅猛之势发展,AIGC(人工智能生成内容)在各个领域的应用也日益广泛。然而AIGC内容的检测与查重问题也随之而来。对于学术研究者而言,确保论文的原创性、避免AIGC内容的滥用极为重要。今日,为大家推荐5款免费的AIGC检测工具,助力你在2025年轻松完成论文查重。 1. 学术云端AI写作助手 工具简介 学术云端是一款聚焦于论文领域的神级工具,它每天都能为用户提供无限次免费的AIGC率检测服务。该工具不仅可以高效检测论文中的AIGC内容,还具备一系列降重和降低AIGC率的实用功能。 主要功能 * 无限次免费改稿:用户下单后都能无限次AI改稿,无需担忧次数受限的问题。 * 专业降重建议:学术云端会提供详细的降重建议,帮助用户优化论文的结构。 * 智能同义词替换:它能够自动识别并替换高重复率的词汇,以此提升论文的原创性。 使用体验 学术云端的操作界面简洁易懂,用户只需上传论文文档,系统便会自动进行AIGC率检测,随后生成详细的检测报告。此外学术云端还配备了丰富的降重工

Apache Arrow Flight_高性能流式数据传输协议的实现与应用

1. 引言 Apache Arrow Flight 概述 * 高性能流式数据传输协议:Apache Arrow Flight 是基于 Apache Arrow 的高性能流式数据传输协议,专为大规模数据传输而设计 * 零拷贝传输:利用 Arrow 的内存布局实现零拷贝数据传输,极大提升了数据传输效率 * 跨语言支持:支持 Java、C++、Python、R 等多种编程语言,提供统一的 API 接口 流式数据传输的重要性 * 大数据处理需求:在现代大数据处理场景中,高效的数据传输是关键瓶颈 * 实时处理要求:流式传输满足实时数据分析和处理的需求 * 分布式系统:在分布式计算环境中,数据传输效率直接影响整体性能 Arrow Flight 的设计目标 * 高性能:通过零拷贝技术和优化的序列化机制实现最高性能 * 标准化:提供标准化的数据传输协议,促进生态系统互操作性 * 可扩展性:支持各种数据源和处理框架的集成 2.

3大核心突破!开源ROS驱动的智能割草机器人,重新定义庭院自动化

3大核心突破!开源ROS驱动的智能割草机器人,重新定义庭院自动化 【免费下载链接】open_mower_ros 项目地址: https://gitcode.com/gh_mirrors/op/open_mower_ros 您是否曾在周末被草坪修剪工作占据整个上午?是否担心昂贵的商用割草机器人无法适应复杂庭院地形?是否渴望拥有一个既能节省时间又能自由定制的智能解决方案?基于开源ROS项目的智能割草机器人,正是为解决这些痛点而生的创新方案。它不仅提供了低成本的家庭草坪维护方案,更通过自主导航割草技术,让庭院自动化变得触手可及。 🔍 庭院维护的3大核心难题 现代家庭在庭院维护中面临着诸多挑战,这些问题不仅耗费时间精力,还常常成为家庭生活质量的隐形负担。 时间成本困境:传统割草机需要人工操作,平均每次修剪500平方米草坪需花费1-2小时,按每月4次计算,每年将占用近100小时的宝贵时间。对于双职工家庭而言,周末的草坪维护往往成为挤占家庭休闲的主要因素。 地形适应局限:商用机器人普遍存在地形适应性差的问题,遇到坡度超过15°的区域、障碍物密集的复杂环境或不规则形状的草坪时,常常出