当前位置:首页 > 智能硬件 > 智能硬件
[导读]软件开发过程中 Bug 的存在无可避免。对工程师来说,“找 Bug 修 Bug”是一趟没有终点的旅程,工作中必须为此消耗大量时间与资源,因此开发者多半都非常期望能有快速、高质量的机器人来搜寻错误代码并协助修补。

1789年本杰明•富兰克林写道:“在这个世界上,除了死亡和税收外,没有什么可以说是确定无疑的。”但如果富兰克林生活在现代,他可能会另外添加“软件bug”这一项。

软件开发过程中 Bug 的存在无可避免。对工程师来说,“找 Bug 修 Bug”是一趟没有终点的旅程,工作中必须为此消耗大量时间与资源,因此开发者多半都非常期望能有快速、高质量的机器人来搜寻错误代码并协助修补。

修 Bug 是所有软件开发计划的常见过程,计算机科学家早就知道自动化编写修补程序理论上可行,但不清楚的是机器人程序能否像人类一样快速完成这项工作并达到相同的质量。以目前来说,尽管许多研究人员已开发出可自动完成这项过程的机器人,但不是速度太慢就是写的代码不够好到能用。

经过数年努力下,瑞典皇家理工学院(KTH)马丁•蒙佩卢斯(Martin Monperrus)团队成功测试出有人类竞争力的机器人“Repairnator”,团队认为这是自动化修复研究的里程碑。

Repairnator的自动程序员编写的补丁好得足以骗过真正的人类工程师,但团队如何证实它“具人类竞争力”?其实答案很简单,那便是让 Repairnator 伪装成人类开发员,在 GitHub 协助产生修补程序来修复漏洞,看看人类开发者能否接受其为对代码库的有效贡献。

团队为 Repairnator 建了一个名为 Luc Esape 的 GitHub 用户,看起来似乎就是研究实验室的软件工程师。为了让 Luc 的存在更真实,团队还上传了一张个人照片,让它看起来就像初级开发人员渴望在 GitHub 对开源大力贡献。

 

 

这种欺骗很有必要,因为人类版主往往以不同的视角或标准来评估机器人的工作和人类的工作。蒙佩卢斯和他的团队认为:“为了测试与人类相竞争的科学假设,这种伪装必不可少。”他们现在已向相关人员告知了真相。

2017 年 2~12 月,团队进行第一次实验,让 Repairnator 原型持续在 14,188 个 GitHub 项目的固定列表寻找错误;Repairnator 每天约能执行 30 次修 Bug 尝试,在这段期间,Repairnator 分析超过 11,500 个漏洞,并能在 3,000 多个案例中重现失败,最终开发了 15 个案例的修补程序。

 

 

但这些修补程序最终都没有被接受,因为 Repairnator 不是花太长时间开发,就是编写修补程序的质量过低而没有被使用者接纳。

相较之下,第二次实验就较成功。虽然团队并未具体说明改进 Repairnator 哪些地方,但 2018 年 1~6 月期间,团队让它透过 Travis 持续向开发者提供协助。而在 1 月初,Repairnator 编写的修补程序首次被人类开发者接受。

 

 

(Source:arXiv.org)

接下来 6 个月里,Repairnator 继续制作的 5 个修补程序也都顺利被人类使用者接纳。团队认为这项令人印象深刻的工作为新一代软件开发奠定了基础,同时也引申出一些有趣的问题。

5 月 12 日 Repairnator 为 GitHub 项目“eclipse/ditto”开发修补程序后,收到开发人员的信息:“我们只能接受签署 Eclipse Contributor Agreement 协议用户的协助修订(Pull Requests)。”

蒙佩卢斯认为,这引申出一个有趣的问题,因为机器人无法签署许可协议。“谁有机器人贡献的知识财产权和责任──机器人操作员,机器人执行者还是修复算法的设计师?”

在人类和机器人更密切合作之前,这类问题必须解决。但蒙佩卢斯对此非常乐观。“我们相信 Repairnator 预先展示了软件开发的某种未来,机器人和人类将会好好合作,甚至携手开发软件。”

最后,我们可以用一句网络上的段子来结尾:

“你已经是个成熟的软件了,要学会自己调参修 Bug。”

参考论文:《用Repairnator自动修复程序,编写出与人类不相上下的补丁》

 

 

 

 

 

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

上海2024年4月22日 /美通社/ -- 恶性的攻击和意外事件总是防不胜防,提前部署灾备方案可以在遭遇意外时尽可能减少企业损失。那么面对无处不在的勒索病毒和潜在风险,为什么依然有很多企业还会遭遇数据丢失?

关键字: 勒索病毒 软件 电脑 群晖数据

SAP(思爱普)近日发出的裁员计划,不仅涉及全球范围内约8000个职位,更是在中国区造成了近1500名正式员工和合同工不续的情况。

关键字: 软件 互联网

上海2024年4月17日 /美通社/ -- 每年4月17日是世界血友病日。今年,世界血友病日以"认识出血性疾病,积极预防和治疗"为主题,呼吁关注所有出血性疾病,提升科学认知,提高规范化诊疗水平,让每一位出血性疾病患者享有...

关键字: VII 动力学 软件 BSP

德国埃朗根2024年4月16日 /美通社/ -- Elektrobit 今日宣布推出 EB zoneo GatewayCore——首款支持、配置和集成现代微控制器新一代硬件加速器的软件产品,可应用于先进的汽车电子/电气架...

关键字: 汽车 软件 硬件加速 通信网络

Windows Embedded Compact 7(简称WinCE)是一种专为嵌入式系统设计的操作系统,具有体积小、效率高、可定制性强的特点。在WinCE中设置自动运行软件,通常是为了满足设备在启动后自动执行特定任务的...

关键字: 嵌入式系统 软件 操作系统

近日某厂员工爆料,公司程序员因线上流量异常BUG事故,被公司进行处罚。处罚的结果是被要求将去年发的 4 万多年终奖归还给公司,否则就收取滞纳金并辞退,逾期将以每天万分之 5 的利息收取滞纳金。

关键字: 程序员 BUG 事故 年终奖 工程师

业内消息,日前欧洲软件巨头SAP宣布了一项重组计划推动人工智能增长,该计划将涉及大约8000名员工的岗位调整,这些员工将被纳入自愿休假计划和内部再培训措施,即鼓励员工自愿离职或进行内部转岗。

关键字: AI 重组 软件 裁员 SAP

近日,运营商乱收费冲上热搜!一名刚被辞退的工程师向河南电视台都市频道节目爆料了联通公司业务创收的丑闻。

关键字: 工程师 运营商 光猫 联通

业内消息,国家工信部近日公布了今年前三季度我国软件和信息技术服务业的具体情况,整体运行态势平稳,软件业务收入两位数增长,利润总额保持较快增长,软件业务出口降幅收窄。

关键字: 工信部 软件

本文中,小编将对嵌入式软件/硬件工程师予以介绍,如果你想对嵌入式软件/硬件工程师的详细情况有所认识,或者想要增进对嵌入式的了解程度,不妨请看以下内容哦。

关键字: 嵌入式 嵌入式软件工程师 硬件工程师 工程师
关闭
关闭