无论你是软件开发新手还是拥有几十年的丰富经验,总是需要学习新知识。TIOBE Index追踪50种最受欢迎的编程语言,许多生态系统为职业发展和横向转型提供了机会。鉴于现有技术具有的广度,抽空学习一项新技能并有效运用技能可能困难重重。
最近我一直在尝试学习Rust语言,这是一种注重性能、可靠性和生产力的类型安全语言。我在此过程中学到了使用AI编程助手的若干技巧,想与你分享,以改善你的学习体验。
文章最后列有几项基于AI的新技能,你可以在学习过程中运用起来,加快实现目标。我在本文所说的AI是指基于大语言模型(LLM)的AI驱动的编程助手,比如Amazon Q Developer(前身是CodeWhisperer)、GitHub Copilot和JetBrains AI Assistant。你可以将下面所有技巧运用到所选择的工具上。
对参数化知识持怀疑态度
“参数化知识”是训练过程中存储在模型中的信息。编码数据是AI通常能够快速响应、提供准确信息的原因。不过,AI有时候也会给出严重错误的答案。
这对我们用户来说意味着什么?虽然这些系统可能大有帮助,但它们受到收集数据和训练模型所需的时间和资源的限制。比如说,OpenAI使用截至2023年12月的信息训练ChatGPT 4 Turbo模型,数据集的内容是未知的。从用户的角度来看,任何特定的模型中是否存在“完整”的知识、为什么有时我们可能对其响应不感兴趣都是不确定的。
留意数据集的截止日期可以帮助你更好地理解和处理来自AI聊天会话的响应。作为一名物色和购买服务的消费者,研究提供商的数据收集实践和训练过程可以带来更令人满意的体验。
虽然AI通常会有所帮助,但在任何学习过程中,经过验证的人类知识来源仍将是最有价值的。这倒不是说AI系始终是错的,但你需要养成质疑自己使用的信息是否正确的习惯。另一个需要谨慎的原因是,这些系统的创建者将它们训练成乐于助人的助手。有时它们可能“太乐于助人”了,生成可能不存在的想法和概念,即幻觉现象。
总而言之,只有“真正的智能”才能理解AI何时犯错。
阅读代码和提示以解释
开源软件运动为每个学习编程的程序员提供了轻松访问生产级代码的途径。开源代码库提供了一个很好的机会,可以了解专业人员如何编写代码,并学习语言习惯用法和技巧等。但是如果没有基本的参考框架或基本的理解,阅读一门不熟悉的语言可能令人生畏、一头雾水。
我一直在使用的一种技术是在流行的代码共享网站GitHub上查找特定语言的代码,并将其粘贴到AI聊天会话中,一并粘贴的还有提示“请解释该代码”和“请列出该代码块中出现的重要语言概念”。
该提示的模板可能如下所示。
Please explain the following code
```rust
// rust code goes here
```
Also, list the important language concepts from the description in a bulleted list so I may do more research.
因此生成的主题列表是一种很好的方式,可以让我把学习的重点放在当下最重要的事项上,而不是试图一次吸收整个图书馆的信息。
JetBrains AI Assistant将允许你存储提示模板供重复使用,你在不同的项目之间跳转时这非常有用。
详细内嵌注释的提示
当你还没有完全掌握一门语言的语法或语义时,一大堆代码可能让人望而生畏。使用提示“为每行注释”是一种快速而简单的方法,可以大致了解应用程序可能在做什么。
借助JetBrains AI Assistant,你还可以在并排或统一视图中获得变更的Diff视图。视图允许你快速查看变更,并选择接受或拒绝变更。
尝试不同的选项
学习任何主题都涉及试验,更重要的是,涉及运用学到的概念。这对于找到一种切实有效的解决方案并理解何时尝试不同的方法至关重要。有了AI,尝试不同的实现方法从未像现在这样直观简单。
下面是我用来发现Rust语言中便于进行后续研究的功能特性的提示。
Given the following API, show me three different implementations
```rust
fn add(x: i32, y:i3) -> i:32 {
// implementation goes here
}
```
记住,这事关学习,所以API不一定特别复杂。尝试想法让你得以发现AI聊天会话之外的不同学习路径。这种技术非常出色,特别是与传统的主题搜索相比;传统的主题搜索可能因你对特定主题的理解而受到限制。
Amazon Q Developer等一些工具提供内联选项,允许你在不离开编辑器上下文的情况下循环处理示例。按左右方向键可以让你在诸选项之间移动,直至找到一个你喜欢的选项。
更多的上下文始终更好
我在上面提到了LLM的嵌入信息限制。请记住,在这些服务可能缺乏信息的地方,能提供信息再好不过了,但你需要用正确的方式来提供。
在现代互联网搜索体验的训练下,我们已学会在文本框中提出基于关键字的问题。搜索式查询是我看到许多AI新手常犯的一个错误,这可能会让他们对结果感到失望。在使用AI助手时,将AI聊天会话视为“搜索”是一个坏习惯,因为LLM的创建者构建它们是为了预测用户可能想要什么。
进行更准确预测的最好方法是尽可能地详细和明确。
一个很有效的方法是基于示例的提示。你提供的示例越多,结果就越准确。这里有一个模板提示,可以帮助你在学习过程中发现新的想法。
Given the following three examples, what would an implementation for <X> look like?
example 1:
```
```
example 2:
```
```
example 3:
```
```
你在聊天会话中输入的数据提供了实现预期结果所需的上下文。别害怕纠正或添加更多的上下文。越多越好,因为模型有更多的信息作为响应的基础。
为了保持对话进行、增添聊天会话的上下文,Amazon Q Developer为你提供了一组自然的后续问题,确保你在学习过程中有积极性。
查看代码补全
大多数AI服务提供多行代码补全功能。虽然我忍不住会接受编辑器中呈现的所有选项,但这通常会阻碍我的学习过程。相反,我喜欢从创建表明目标的代码注释入手。
// TODO: create a match expression to process the different message variants
在下图中,我们看到GitHub Copilot主动表示可以补全我的语句。乍一看很不错,但我必须停下来细想这个选项,看看它是否符合我的意图。在按Tab键之前,我要停下来。想想为什么?
这么做的原因是为了检查我目前的技能是否能够阅读和处理代码。如果是,那我取得进展。如果不是,那么我应该花时间去了解我的知识短板在哪里。永远不要接受你并没有完全理解的代码、添加到代码库中。
注意,你可以配置该功能以减少干扰,只按需显示补全,以减轻在编写代码和读取代码之间切换的认知负担。
解释错误,找到解决办法
面对每个编程堆栈,你都会遇到编译和运行时错误,其中一些错误可能很隐晦。如果你在设法理解为什么你的应用程序失败,不妨使用AI助手聊天会话来解释这个问题,找到出现问题的地方,并提出解决方案。
What exactly is the problem here in my Rust backtrace? Reduce the response to the file and line and explanation of the error and propose a solution.
```
```
下面这个例子表明了使用这个提示来理解Rust回溯中发生了什么事情。
分享想法
虽然使用AI聊天从一个话题切换到另一个话题可能感觉很自然,但放缓节奏、将你新发现的知识与其他知识重新联系起来总是好事。一旦我学到了新概念,并创建了切实可用的示例,我会与其他学习者和专家分享,以获得宝贵的反馈。记住,AI只能对你的要求有所帮助,而其他人会用他们的实际经验加以丰富,预测你可能忽略的潜在陷阱。
社交媒体平台是分享截图、代码示例和想法并获得宝贵反馈的好地方,你可以将这些反馈纳入到未来的AI聊天会话中。
总结聊天
这里有一个建议送给那些不擅长记笔记,但可能想要回忆前一天工作的那些人。在长时间的学习结束后,不妨让当前的聊天会话总结你的所有问题,并为每个问题列出一句话的答案。
Given what we’ve chatted about, list all the questions and a single-sentence summary of each answer.
响应是出色的快速参考指南,供你的下一次学习会话参考。这也是一篇很好的博文,你可以练习与他人分享你的想法和学习经验。
用AI学得更快
我希望当你使用AI工具更快速、更有效地学习时,这些技巧对你有所帮助。这些工具旨在帮你实现为自己设定的目标。我发觉它们在形成新想法和探索我不知道的想法方面大有帮助。
最重要的是,它们让我与社区里的其他人建立了联系,这些人拓宽了我的知识面。