二、GitHub Copilot 和豆包 MarsCode 简介
v0.dev
你告诉它,想要什么网站,它就给你几张设计图。你选一张,它就生成写好的网页。但它只能生成网页 UI(用户界面),无法生成互动脚本,并且其他的 UI(比如手机 App 页面),它都无法生成。
GitHub Copilot
GitHub Copilot 是最早出现的 AI 编程助手,也是市场占有率和知名度最高的一个。
它是微软出品,底层是 OpenAI,又依托着世界最大的程序员社区,自然是实力非凡。
豆包 MarsCode。
豆包 MarsCode 是基于豆包大模型打造的智能开发工具。
它的背后是字节跳动,本来是内部工具,据说字节超过70%的工程师都在用,每月贡献百万行量级的代码。
三、使用环境
都支持目前最流行的 VS Code。此外,豆包 MarsCode 还支持 Jetbrains IDE,Copilot 则支持更多。
如果你没有 VS Code,甚至也没有其他 IDE,问题也不大。豆包 MarsCode 提供免费的云 IDE(下图),无需下载和安装,直接在浏览器使用,并且内置数十款开发模板,还可以拉取 GitHub 仓库,用起来很方便。
GitHub 也有云 IDE,就是它的 CodeSpace,里面也能用 Copilot。不过,每月使用60小时之后,就要收费,这里就不推荐了。
五、代码生成
用很简单,只要有按键输入,它就会自动建议后面的代码是什么。
你可以将其当作参考,也可以按下 Tab 键,接受它为正式代码。如果想逐个单词确认,按下 Ctrl + 右箭头(Mac 为 Cmd + 右箭头)。
我让 AI 生成一个检验电话号码的函数。
另外,如果对给出的实现不满意,Copilot 可以按下 Ctrl + Enter,会有多种实现供选择(下图)。
豆包 MarsCode 则是在代码建议时,有一个浮动工具栏,可以切换多种实现(下图的箭头)。
值得一提的是,豆包 MarsCode 还有一个特色功能”代码补全 Pro”,不需要手动给出提示,根据现有代码,自动预测下一个改动点,并给出推荐代码。
这个功能需要自己在设置里面打开(下图)。
打开以后,它就会加强代码预测。首先,在期望触发代码推荐的地方,按下 Ctrl + Shift + Enter 主动触发推荐,然后你按下 Tab 采纳。
这时,它会预测下一个改动点,点击 Tab 就可以跳转到那里。这在代码修改的场景中非常有用,修改了一个地方,它帮你跳到下一个(预测的)改动点,并给出推荐代码。普通的代码补全做不到这一点。
六、生成注释,代码解释
除了生成代码,AI 的另一个重要作用,就是生成编程文档,也就是代码的文字说明。
文档功能主要有两种:注释和代码解释。首先,Copilot 的注释需要自己手动生成。
豆包 MarsCode 则在代码上方有生成注释的快捷按钮。
点击后会唤起/doc
命令,用起来相对方便一点。
至于代码解释功能,我觉得相比之下,豆包 MarsCode 更好一些,Copilot 太冗长了,有点不易读。
七、其他功能
(1)代码翻译
它们都能够将一种语言的代码,翻译成另一种语言。
我试了 JS 代码翻译成 Python,没有任何问题。豆包 MarsCode 还会自动将翻译后的代码,保存成当前目录下的一个单独文件。
(2)生成单测
单元测试写起来很麻烦,AI 能够自动生成,真是省事不少。
同一段代码,Copilot 生成了4个测试用例,豆包 MarsCode 生成了5个。
并且,豆包 MarsCode 对测试用例有文字总结(下图),这很有用,可惜 Copilot 没有。
(3)修正错误
AI 还可以自动修改报错的代码。如果测试用例或者自动构建没有通过,它会解释报错的原因,并给出修改建议。这里就不举例了。