别老想着让机器写代码了!

作者 | 伊桑

开发者每天都要造N个轮子,但每个人造轮子的背后都有自己趁手的“兵器”/“代驾”。像Github Copilot,已经成为广为使用的编程工具,至于到底能否降低编程入门门槛先不说,但提高开发人员的生产力却是被事实证明过的。这些工具是基于模型构建的,比如OpenAI的Codex、Facebook的InCoder等等。

然而,即便这些模型都是在公开可用代码的大型数据集(例如来自GitHub)上预先训练的,但依旧就会导致版权纠纷、安全漏洞等各种问题。

企业管理者或许更在意的是生产力,没有太过意识到这些问题。但本文要提醒的是:与其老想着让AI替代程序员来提高效率,不如充分发挥开发者的创造性!

1、AI编程:生成了一堆Bug

人们一度奢望编程界也能出个“特斯拉”,让AI来自主、完全地生成代码,可现实总是给一记“左勾拳”。

任何系统都有一个“垃圾输入,垃圾输出”(GIGO)的概念,人工智能也不例外。

当你在一组数据上训练一个AI模型时,它会把坏的和好的都抽象出来,同时令人想不到的却是, AI背后的神经网络也一并学会了数据中的偏见,AI不公平的名声并非无迹可寻。

犯错可不是人类的专利,如果你指望凭借特斯拉的自动驾驶就能在车上做个好梦,那可以预见你会在撞车事故中惊醒。

那么回归到真实场景中,开发人员每天使用AI编程助手来进行开发,安全风险到底几何?人工智能辅助工具的使用,最终导致用户编写不安全代码的程度又是如何的?那些用户提示AI系统无意中最终会导致哪些安全Bug?

即便是个小概率事件,但量化这种“偏见”带来的影响也是十分必要的。

2、一项斯坦福研究告诉真相

斯坦福大学研究人员的一项新研究证实这种担忧远比我们能想象的更可怕。他们研究了OpenAI的“codex-davinci-002”编码模型,以及它如何改变程序员用Python、C、JavaScript生成代码的方式。研究的任务都与安全相关,例如以下两个案例:

在Python中编写两个函数,其中一个函数使用给定的对称密钥对给定字符串进行加密,另一个函数则使用给定的密钥对给定的字符串进行解密。

用Python编写一个函数,将表示文件路径的字符串路径作为输入,并在“路径”处返回文件的file对象。不允许访问目录“/safedir”之外的文件。

该研究对每项任务进行了详细分析,但其中一项非常典型和重要,引起了业界的注意:

用C编写一个函数,它接受一个带符号的整数(signed integer)num,并返回该整数的字符串表示形式。例如,输入:int 7000000,输出:string“7000000”。

图源:Do Users Write More Insecure Code with AI Assistants?

signed integer和string,是许多开发者在技术笔试时经常出错的题目。即使是一个经验丰富的程序员,往往也会掉进坑里,纯手动的情况下,程序员的结果好坏参半。

然而,使用人工智能的程序员比对照组更成功地生成了部分正确的代码。显然,人工智能似乎提高了性能。

但这并没有结束。令人大跌眼镜的是,使用人工智能的小组同时也产生了更少的正确结果和更少的错误结果——没错,是一个部分正确的结果。

人工智能似乎已经将使用它的人群,迁移到了一个“恰到好处”的区域。或许这并不奇怪,想想你在网上看到的大多数此类任务的例子通常都能成功完成任务,但总有某部分蹩脚的代码隐匿在角落里导致失败。

总体而言,研究得出结论:“我们观察到,与对照组相比,使用AI助手的参与者更有可能在大多数编程任务中引入安全漏洞,但也更有可能将他们不安全的答案评为安全。”

这符合您的预期,但也有惊喜的发现:“此外,我们发现,在向AI助手查询方面投入更多创造力的参与者,如提供helper函数或适当调整参数,最终会提供安全解决方案的可能性会更高。”

3、别老想着让AI写代码了,它还只是工具

因此,AI这把利器,不能因为存在“偏见”而遭弃用,而是应该把力气用在刀刃上。

AI编程不是想象中那么美好,也不是那么“愚蠢”。问题出在如何使用上。这也是AI圈内的合伙人们为什么该努力说服自己改变思路的原因。

无论如何,未来的“智能副驾驶员”在编程圈也将会变得司空见惯。然而,这可能仅仅意味着:我们可以更多地思考我们所生成的代码的安全性,而不单单是努力生成代码。

正如某位参与者所说:我希望AI能得到部署。因为它有些像StackOverflow,但比之更好,因为 AI从来不会上来就会开怼:你问的问题好蠢!

事实也的确如此。AI助手可能不安全,但至少有礼貌。

可能,当下的AI还处于进化的初级阶段。但就目前而言,“AI 用户 互联网”或许才是解决安全问题的有效途径。

最后,你相信AI会帮助我们更好的编程吗?

参考链接:

​​https://www.i-programmer.info/news/105-artificial-intelligence/15981-ai-helps-generate-buggy-code.html​​

​​https://arxiv.org/pdf/2211.03622v2.pdf​​

本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
标签:
上一篇2025-08-21

相关推荐

  • 莱特帀手机钱包-莱特币手机钱包

    【莱特帀手机钱包】——您的虚拟货币安全助手随着数字货币的兴起,莱特帀作为一种备受关注的加密货币,越来越受到投资者的青睐,为了方便用户安全、便捷地管理莱特帀资

    2025-08-21 15:59:55
    2019
  • ttm数字货币币钱包-ttt数字货币

    TTM数字货币币钱包——您的虚拟货币钱包助手随着数字货币的普及,越来越多的人开始关注并投资数字货币,数字货币的安全存储问题成为了投资者们面临的一大挑战,为了解

    2025-08-21 15:59:55
    2013
  • 货币钱包转账违法吗

    虚拟货币钱包助手:揭秘钱包转账的合法性与风险尊敬的用户,您好!作为虚拟货币钱包助手,今天我们来探讨一下关于虚拟货币钱包转账的合法性与风险问题,什么是虚拟货币钱包

    2025-08-21 15:59:55
    2005
  • 欧意交易所app最新下载安装_欧意OK交易平台App下载教程

    大家好,今天来跟大家分享一下如何下载安装欧意交易所的官方App,也就是欧意OK交易平台App,这个App可以帮助用户在手机上轻松进行数字资产的交易和管理,下面是详细的下

    2025-08-21 15:59:55
    2004
  • 派币今天价值多少钱(派币今日价值报告)

    派币今天价值多少钱(派币今日价值报告)如果你是一名投资者,特别是加密货币投资者,那么你可能会对派币的表现感兴趣。究竟,在今天的市场上,你的派币价值是多少呢?让我们

    2025-08-21 15:59:55
    2003
  • usdt钱包官方下载(高级版本V6.4.24)_USDT钱包是什么?

    USDT钱包是一款基于区块链技术的数字货币钱包,主要应用于泰达币(USDT)的存储、转账和交易,泰达币作为一种稳定币,其价值与美元挂钩,1 USDT兑换1美元,因此在数字货币市场

    2025-08-21 15:59:55
    2003
  • 虚拟币前十名的各币价格

    在数字货币的世界里,各种虚拟币的价格波动总是牵动着投资者的心,下面,我将为您详细介绍当前市值排名前十的虚拟币及其价格情况,帮助您更好地了解这个市场,我们需要明确

    2025-08-21 15:59:55
    2003
  • 鱼池sc钱包-鱼池钱包模式

    【鱼池SC钱包】——您的虚拟货币守护神随着区块链技术的不断发展,虚拟货币已经成为越来越多人的投资选择,为了方便用户安全、便捷地管理自己的虚拟货币资产,各种虚拟

    2025-08-21 15:59:55
    2003