【AI】AI编程助手:Cursor、Codeium、GitHub Copilot、Roo Cline、Tabnine

news2025/3/21 21:48:42

文章目录

  • 一、基本特性对比
  • 二、收费标准
  • 三、私有部署能力
    • 1、Tabnine
    • 2、Roo Code
  • 三、代码补全与自然语言生成代码
  • 四、安装
    • 独立的IDE安装
    • 插件安装
  • 五、基本使用
    • (一)Cursor
    • (二)GitHub Copilot
      • 1、获取代码建议
      • 2.聊天
        • 1)上下文
        • 2)Chat participants
        • 3)Slash Commands
        • 4)切换AI模型
        • 5)Inline Chat
        • 6)Terminal Inline Chat
        • 7)智能操作
      • 3、Copilot Edits
      • 4、自定义指令
    • (三)Windsurf/Codeium
  • 参考

一、基本特性对比

在这里插入图片描述

二、收费标准

Cursor:https://www.cursor.com/pricing
Windsurf/Codeium: https://codeium.com/pricing
GitHub Copilot: https://github.com/features/copilot/plans
Tabnine: https://www.tabnine.com/pricing/

三、私有部署能力

Tabnine与Roo Code均支持私有部署。

1、Tabnine

它仅支持企业客户,可以选择部署一个私有的、自托管版本的 Tabnine 集群。

部署选项

  • 在 AWS、GCP 或 Azure 上的虚拟私有云(VPC)
  • 在您自己的服务器上进行本地部署

私有安装可以部署在完全隔离的环境中。

官方文档:https://docs.tabnine.com/main/administering-tabnine/private-installation

2、Roo Code

它是通过Ollama 或 LM Studio实现的。
官方文档:https://docs.roocode.com/advanced-usage/local-models

三、代码补全与自然语言生成代码

除Tabnine外,其他均支持所有的主流语言,Tabnine仅完全支持JavaScript、TypeScript、Python、Java、C++、PHP,明细见https://docs.tabnine.com/main/welcome/readme/supported-languages

四、安装

独立的IDE安装

Cursor:https://www.cursor.com/

Windsurf/Codeium:https://codeium.com/windsurf/download_confirmation?code=ma

插件安装

GitHub Copilot:vscode://GitHub.copilot/
Tabnine:支持多个IDE

  • vscode:vscode:extension/TabNine.tabnine-vscode

Roo Cline:vscode:extension/RooVeterinaryInc.roo-cline

五、基本使用

(一)Cursor

https://mp.weixin.qq.com/s/tCpW_Dt-Vy2CYjyUHeFL4g

(二)GitHub Copilot

官方文档:https://code.visualstudio.com/docs/copilot/overview

安装完VSCode插件后,可以在这里打开它:
在这里插入图片描述

1、获取代码建议

与Cursor类似,输入后Copilot会自动建议函数的剩余部分,如果接受,按Tab;如果拒绝,按Esc。
在这里插入图片描述
根据注释生成代码:
在这里插入图片描述
它也支持多个建议:
在这里插入图片描述
支持快捷键切换:
在这里插入图片描述

如果只想接收部分建议,可以使用快捷键⌘→。

2.聊天

安装完VSCode插件后,可以在这里打开聊天窗口,或使用快捷键Control+Command+i (Mac) / Ctrl+Alt+i (Windows/Linux):
在这里插入图片描述

1)上下文

默认上下文是你当前打开正在看的文件,或当前选中代码,如果你想更改上下文,有的几种方式:

  • 拖拽文件进聊天窗口
  • 点击链接的按钮(⌘/),然后从Quick Pick 菜单中选择一种上下文类型:

在这里插入图片描述
通过输入# 字符,也可以使用聊天变量(Chat Variables),并看到可用的变量列表。

  • #codebase:将整个代码库作为上下文提供给 Copilot Chat,当希望 Copilot 参考整个项目结构、文件关系或全局逻辑时使用。
  • #editor:将当前活动的编辑器内容作为上下文,当希望 Copilot 基于当前编辑器中的完整内容进行解释、修复或优化时使用。
  • #file:从工作区中添加特定文件的内容或路径。
  • #selection:将当前编辑器中选中的代码添加到聊天提示中。
  • #sym:添加工作区中的某个符号(如函数名、类名或变量名)。
  • #terminalLastCommand:将终端中最近运行的命令作为上下文提供给 Copilot Chat,当需要调试、优化或解释终端命令时使用。
  • #terminalSelection:将终端中选中的文本作为上下文提供给 Copilot Chat,当需要详细分析选中的终端输出内容时使用,比如错误日志。
  • #vscodeAPI:将 Visual Studio Code 提供的 API 作为上下文,用于帮助开发扩展或自动化工作流程,当需要了解 VS Code API 的功能或如何使用特定 API 时使用。
    在这里插入图片描述
  • 直接右击文件选择:
    在这里插入图片描述
2)Chat participants

这个就像领域专家,可以在其专业领域提供帮助。使用时直接在聊天输入框中键入@会展示所有的:
在这里插入图片描述

@github:了解并具备处理 GitHub 仓库、问题(Issues)、拉取请求(PRs)等相关操作的技能;它额外还可以使用 Bing API 执行网络搜索。比如:

  • 检查或管理 GitHub 仓库中的问题和 PR。
  • 查询代码库相关的信息。
  • 搜索与开发或代码相关的网络资源。

@terminal:了解集成终端(shell)及其内容。比如:

  • 协助调试终端命令。
  • 解释终端输出内容。
  • 帮助优化或修复终端中的命令操作。

@vscode:了解 Visual Studio Code 的功能、设置及其 API。比如:

  • 指导使用 VS Code 的特性或快捷键。
  • 帮助调整 VS Code 设置。
  • 提供与 VS Code API 相关的开发建议或示例代码。

@workspace:了解工作区中的代码。比如:

  • 帮助导航代码库。
  • 查找相关的类、函数或文件。
  • 提供有关代码结构、交互或设计模式的建议。

你也可以从Visual Studio Code Marketplace或GitHub Marketplace安装其他的Chat participants。

  • Visual Studio Code Marketplace:https://marketplace.visualstudio.com/search?term=tag%3Achat-participant&target=VSCode&category=All%20categories&sortBy=Relevance
  • GitHub Marketplace:https://github.com/marketplace
3)Slash Commands

它提供了一种快捷方式,用于执行特定的指令,从而避免编写复杂的提示。只需输入/字符,然后输入命令即可,Chat participants也可以贡献自己的斜杠命令。

在这里插入图片描述

常用内置斜杠命令:

  • /clear:开始一个新的聊天会话。
  • /help:获取关于使用 GitHub Copilot 的帮助。
  • @workspace /explain(或/explain):解释选定代码的功能。
  • @workspace /fix(或/fix):提出修复选定代码问题的建议。
  • @workspace /new(或/new):为新工作区或新文件生成代码框架。
  • @vscode /runCommand:搜索或运行一个 VS Code 命令。
4)切换AI模型

可以在聊天窗口点击AI模型切换:
在这里插入图片描述
以下是当前Copilot Chat 使用的模型:

  • GPT 4o: 这是 Copilot Chat 的默认模型,它是一个多功能的多模态模型,在文本和图像处理方面表现出色,旨在提供快速可靠的响应;它在非英语语言方面也有出色表现;该模型部署在 Azure 上。
  • Claude 3.5 Sonnet: 该模型在整个软件开发生命周期的编码任务中表现出色,包括初始设计、bug修复、维护和优化;GitHub Copilot 使用部署在 Amazon Web Services 上的 Claude 3.5 Sonnet。
  • Gemini 2.0 Flash: 该模型具有强大的编码、数学和推理能力,非常适合协助软件开发;该模型部署在 Google Cloud 上。o1: 该模型专注于高级推理和解决复杂问题,特别是在数学和科学领域;响应速度比 GPT 4o 模型慢;每天可向该模型发出 10 次请求;该模型部署在 Azure 上。o3-mini: 这是继 o1 和 o1-mini 之后的新一代推理模型;
  • o3-mini 模型在编码基准测试上优于 o1,响应时间与 o1-mini 相当,以几乎相同的延迟提供更好的质量;最适合代码生成和小上下文操作;每 12 小时可向该模型发出 50 次请求;该模型部署在 Azure 上。
5)Inline Chat

支持在编辑器内直接提交prompt并获取代码建议,无需离开当前工作环境;要启动编辑器行内聊天,在任何文件中使用⌘I快捷键;或者打开文件后,从标题栏的Copilot菜单中选择编辑器行内聊天即可。
在这里插入图片描述
Copilot在编辑器中直接显示代码建议,你可以:

  • 接受建议:⌘
  • Enter丢弃建议:Esc

不满意时可以为相同的prompt生成新的代码建议
在这里插入图片描述
当然,你也可以在编辑器中选中某段代码进行询问,不过该行为将限定你的问题限定在该选区范围内(即添加聊天上下文)。

如果想对比行内聊天建议,可以配置 inlineChat.mode 设置为preview:
在这里插入图片描述
设置后效果:
在这里插入图片描述

6)Terminal Inline Chat

和Inline Chat类似,但它作用于命令行,使用的是@terminal聊天参与者,能访问集成终端的 shell 和内容上下文,在命令行中按 ⌘I 快捷键即可启动终端行内聊天:

在这里插入图片描述
若接受建议,可以采用以下快捷键:

  • 执行:⌘Enter
  • 插入:⌥Enter 插入命令到终端
7)智能操作

选中代码右击即可看到Explain、Fix、Review and Comment、Generate Docs、Generate Tests
在这里插入图片描述
上面的入口有点深,不过使用过程中若发现问题,它也会在行内提示:
在这里插入图片描述
当然,选中某些字符,这一行的前面也会出现一个快捷icon:
在这里插入图片描述
可点击展开快捷操作:
在这里插入图片描述
下面是我通过Review using Coplit的结构,若有建议,当前行将加入留言,可以点击展开,另外在命令行中的Comments也可以看到:

在这里插入图片描述

3、Copilot Edits

与Cursor的Composer类似,Copilot的Edits也是直接在多个文件中快速迭代代码,修改会直接应用在编辑器中。

在这里插入图片描述
可以直接点击右上角的tab切换,或使用快捷键⇧⌘I,还可以在标题上展开Copilot的菜单:
在这里插入图片描述

4、自定义指令

与Cursor的自定义指令类似,可以为Copilot提供团队工作流、工具和项目细节,无需在每次对话中重复,它包含四种指令类型:

  • 代码生成 - 定义代码风格,如私有变量前缀规则
  • 测试生成 - 指定测试框架等测试相关要求
  • 代码审查 - 设置代码审查重点
  • 提交信息生成 - 规范提交信息格式

官网文档讲解很详细,有需要可以直接看官网:https://code.visualstudio.com/docs/copilot/copilot-customization

(三)Windsurf/Codeium

参考

  • AI编程助手
  • 【AI】Cursor基本使用

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

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

相关文章

我的uniapp自定义模板

uniapp自定义模板 如有纰漏请谅解,以官方文档为准后面这段时间我会学习小程序开发的知识,会持续更新可以查看我的github,后续我会上传我的uniapp相关练习代码有兴趣的话可以浏览我的个人网站,我会在上面持续更新内容,…

【C++】动态规划从入门到精通

一、动态规划基础概念详解 什么是动态规划 动态规划(Dynamic Programming,DP)是一种通过将复杂问题分解为重叠子问题,并存储子问题解以避免重复计算的优化算法。它适用于具有以下两个关键性质的问题: 最优子结构&…

OpenCV计算摄影学(23)艺术化风格化处理函数stylization()

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 风格化的目的是生成不以照片写实为目标的多种多样数字图像效果。边缘感知滤波器是风格化处理的理想选择,因为它们能够弱化低对比度区…

S32K144外设实验(三):ADC单通道连续采样(中断)

这次的实验比较简单,主要目的就是验证一下ADC的中断功能,思路是使用软件触发ADC的连续单通道采样,将采样值通过串口发送到上位机观察数是否正确。 其实官方并不推荐使用中断的方式,这种方式会占用大量的CPU资源,笔者安…

Web3 时代数据保护的关键挑战与应对策略

Web3 时代数据保护的关键挑战与应对策略 随着互联网技术的飞速发展,我们正步入 Web3 时代,这是一个以去中心化、用户主权和数据隐私为核心的新时代。在这个时代,数据保护成为了一个至关重要的议题。本文将探讨 Web3 时代数据保护面临的主要挑…

SpringBoot之如何集成SpringDoc最详细文档

文章目录 一、概念解释1、OpenAPI2、Swagger3、Springfox4、Springdoc5. 关系与区别 二、SpringDoc基本使用1、导包2、正常编写代码,不需要任何注解3、运行后访问下面的链接即可 三、SpringDoc进阶使用1、配置文档信息2、配置文档分组3、springdoc的配置参数**1. 基…

【智能体】| 知识库、RAG概念区分以及智能体是什么

文章目录 前言简介大模型“幻觉”问题如何解决“幻觉”问题? RAG、智能体、RAG智能体概念什么是检索增强型生成(RAG)模拟简单的RAG场景 AI系统中的智能体是什么什么是Agentic RAG?Agentic RAG如何工作?Agentic RAG架构…

二分查找的应用

什么时候用二分查找&#xff1f; 数据具有二段性的时候 第一题&#xff1a; 题解代码&#xff1a; class Solution { public:int search(vector<int>& nums, int target) {int left 0,right nums.size()-1;while(left<right){int mid left (right-left)/2;//中…

【Function】Azure Function通过托管身份或访问令牌连接Azure SQL数据库

【Function】Azure Function通过托管身份或访问令牌连接Azure SQL数据库 推荐超级课程: 本地离线DeepSeek AI方案部署实战教程【完全版】Docker快速入门到精通Kubernetes入门到大师通关课AWS云服务快速入门实战目录 【Function】Azure Function通过托管身份或访问令牌连接Azu…

Flink 通过 Chunjun Oracle LogMiner 实时读取 Oracle 变更日志并写入 Doris 的方案

文章目录 一、 技术背景二、 关键技术1、 Oracle LogMiner2、 Chunjun 的 LogMiner 关键流程3、修复 Chunjun Oracle LogMiner 问题 一、 技术背景 在大数据实时同步场景中&#xff0c;需要将 Oracle 数据库的变更数据&#xff08;CDC&#xff09; 采集并写入 Apache Doris&am…

WordPress系统获取webshell的攻略

一.后台修改模板拿WebShell 1.进入Vulhub靶场并执⾏以下命令开启靶场&#xff1b;在浏览器中访问并安装好 #执⾏命令 cd /vulhub/wordpress/pwnscriptum docker-compose up -d 2. 修改其WP的模板&#xff0c;登陆WP后点击 【外 观】 --》 【编辑】 --》 404.php 3.插入一句话木…

蓝桥杯2023年第十四届省赛真题-子矩阵

题目来自DOTCPP&#xff1a; 暴力思路&#xff08;两个测试点超时&#xff09;&#xff1a; 题目要求我们求出子矩阵的最大值和最小值的乘积&#xff0c;我们可以枚举矩阵中的所有点&#xff0c;以这个点为其子矩阵的左上顶点&#xff0c;然后判断一下能不能构成子矩阵。如果可…

如何在 Node.js 中使用 .env 文件管理环境变量 ?

Node.js 应用程序通常依赖于环境变量来管理敏感信息或配置设置。.env 文件已经成为一种流行的本地管理这些变量的方法&#xff0c;而无需在代码存储库中公开它们。本文将探讨 .env 文件为什么重要&#xff0c;以及如何在 Node.js 应用程序中有效的使用它。 为什么使用 .env 文…

Redis BitMap 用户签到

Redis Bitmap Bitmap&#xff08;位图&#xff09;是 Redis 提供的一种用于处理二进制位&#xff08;bit&#xff09;的特殊数据结构&#xff0c;它基于 String 类型&#xff0c;每个 bit 代表一个布尔值&#xff08;0 或 1&#xff09;&#xff0c;可以用于存储大规模的二值状…

未来办公与生活的新范式——智慧园区

在信息化与智能化技术飞速发展的今天&#xff0c;智慧园区作为一种新兴的城市发展形态&#xff0c;正逐步成为推动产业升级、提升城市管理效率、改善居民生活质量的重要力量。智慧园区不仅融合了先进的信息技术&#xff0c;还深刻体现了可持续发展的理念&#xff0c;为园区内的…

Hugging Face预训练GPT微调ChatGPT(微调入门!新手友好!)

Hugging Face预训练GPT微调ChatGPT&#xff08;微调入门&#xff01;新手友好&#xff01;&#xff09; 在实战中&#xff0c;⼤多数情况下都不需要从0开始训练模型&#xff0c;⽽是使⽤“⼤⼚”或者其他研究者开源的已经训练好的⼤模型。 在各种⼤模型开源库中&#xff0c;最…

【CSS3】化神篇

目录 平面转换平移旋转改变旋转原点多重转换缩放倾斜 渐变线性渐变径向渐变 空间转换平移视距旋转立体呈现缩放 动画使现步骤animation 复合属性animation 属性拆分逐帧动画多组动画 平面转换 作用&#xff1a;为元素添加动态效果&#xff0c;一般与过渡配合使用 概念&#x…

Unity音频混合器如何暴露参数

音频混合器是Unity推荐管理音效混音的工具&#xff0c;那么如何使用代码对它进行管理呢&#xff1f; 首先我在AudioMixer的Master组中创建了BGM和SFX的分组&#xff0c;你也可以直接用Master没有问题。 这里我以BGM为例&#xff0c;如果要在代码中进行使用就需要将参数暴露出去…

如何理解分布式光纤传感器?

关键词&#xff1a;OFDR、分布式光纤传感、光纤传感器 分布式光纤传感器是近年来备受关注的前沿技术&#xff0c;其核心在于将光纤本身作为传感介质和信号传输介质&#xff0c;通过解析光信号在光纤中的散射效应&#xff0c;实现对温度、应变、振动等物理量的连续、无盲区、高…

PMP-项目运行环境

你好&#xff01;我是 Lydia-穎穎 ♥感谢你的陪伴与支持 ~~~ 欢迎一起探索未知的知识和未来&#xff0c;现在lets go go go!!! 1. 影响项目的要素 项目存在在不同的环境下&#xff0c;环境对于项目的交付产生不同的影响。需了解环境对于项目的影响&#xff0c;采取相应措施应对…