【CSDN编者按】复制和粘贴可能是不安全的,同样地,如果做得不小心,处处会给软件开发埋下祸端。在这篇文章中,作者将研究一下代码复制对软件开发的实际意义,并讨论一下如何高明地“窃取”代码,以及复制错误的陷阱。

作者 | Ryan Donovan

翻译 | 苏本如,责编 | 夕颜

头图 | CSDN付费下载自视觉中国

出品 | CSDN(ID:CSDNnews)

以下为译文:

对于程序员来说,一个公开的秘密是,在Stack Overflow网站上发布的一些作为问题答案的示例代码,最终会出现在生产环境中。也许你在Stack Overflow上问了一个问题,得到了完美的循环交换。也许你找到了一个很好的答案,它包含了完全适合你的应用程序的async await实现。

你需要的最后一本编程书

pic.twitter.com/cnObD8GYGZ

— 开发社区(@ThePracticalDev) 2016年3月4日

因此,当我在推特上看到这条宣传代码窃取好处的推文时,我情不自禁地想:复制和粘贴代码真的有好处吗?

更聪明地工作。

窃取代码。

— Laurie (@laurieontech) 2020年5月14日

复制和粘贴代码可能是不安全的,同样地,如果做得不小心,软件开发的许多方面也可能是危险的。在这篇文章中,我将研究一下代码复制对软件开发的实际意义,并且解释什么是好的代码窃取,以及复制错误的陷阱。

在此申明,我并不主张你随意地从我们的公共Q&A网站复制和粘贴代码,在某些情况下,这样做会给你带来麻烦。然而,正如我们的播客嘉宾Anna Lytical向我们展示的那样,借助此方法确实是可以快速制作出一个功能原型。

如果你复制了示例代码,请记住提供其归属信息。根据代码最后一次在网站上编辑时间的不同,示例代码的归属和许可是依据Creative Commons许可证的某个版本授予的,Creative Commons许可证的最近的一个版本是CC BY-SA 4.00,这个版本需要提供归属信息。

一次编码,数百万次运行

从Stack Overflow上复制代码是代码克隆(复制)的一种形式;从项目内部或项目之间复制代码并重用是代码克隆的另一种行式。取决于你提问的对象,少至5-10%,多至7-23%的代码都是从其他地方克隆过来的。至于克隆代码的方式是好是坏,尚有待商榷。

不管确切的数量是多少,代码克隆都是非常常见的。样板模版代码本质上是在整个项目中定期重复的代码。很有可能有些编码人员在项目过程中从来没有手工输入过一行这样的代码。像Lombok这样的工具试图减少对样板模版的需求,但现实的情况依然是:

  • 一些代码片段在项目中反复出现。

而且:

  • 由于这些代码片段在不同的地方可能需要稍做不同的修改,因此无法将它们归并到单独的函数或依赖项中。

说到库和依赖项,它们是一种在不重用代码的情况下重用功能的有效方法。这几乎就和代码复制一样,只是你不需要负责维护它。今天的大多数Web应用都运行在各种框架和插件库上,这些框架和插件库简化了开发过程。以库的形式重用代码是非常高效的,它让每个功能明确的库非常擅长它所做的事情,并且只做它所擅长的事情。与学术界不同的是,许多库甚至不需要任何东西来表明你正在使用或基于其他人的代码进行构建。

JavaScript包管理器npm将这一点发挥到了极致。你可以通过命令行在项目中安装一些很小的单函数库 – 有些甚至小到只有单行代码。你可以从超过一百万个开源软件包中抓取任意一个你需要的函数库,然后开始在你的应用中构建它们的功能。

当然,和每一种工作方法一样,这种方法也有缺点。通过安装一个软件包,你放弃了对代码的一些控制。一些恶意代码编写者先是创建一个合法有用的软件包,等到这个软件包有了一个像样的采用率后,他们就更新代码来窃取比特币钱包。值得称赞的是,npm的工作人员很快就成功地阻止了这种攻击,然而,你拥有的外部依赖项越多,你的受攻击面就越大。

即使Stack Overflow答案本身也不能免受代码克隆的影响。一位独立的研究人员发现了几个例子,其中一些Stack Overflow的答案是从其他地方复制过来的代码。比如说,一个Java代码片段就在超过40个Stack Overflow答案中出现了。

好的艺术家“借”,伟大的艺术家“偷”

在艺术界,“偷”是伟大作品产生的一部分。我记得去阿姆斯特丹的梵高博物馆看他的一些早期作品的时候。我被震惊了,但当时我不知道的是,这些早期的作品实际上是对日本艺术和木版画的研究。我所认为的在那个时代独居一格的风格,实际上是一个连续统一体的一部分,而且也不是我所认为的连续统一体。梵高并没有沿着荷兰大师们摆在他面前的道路前进,而是从他在巴黎发现的日本版画中汲取构图和笔法的思想,并将其融合进他的绘画作品中。

毕加索有句名言:“好的艺术家‘借’,伟大的艺术家‘偷’”。毕加索本人从非洲和波利尼西亚艺术中汲取了许多思想,并将其与自己的研究结合起来。“偷”听起来是不对的,但是事实上,把别人的作品声称是你自己的才是剽窃。毕加索的这句名言是用“偷”这个词表达了一些不同的意思。一个“借”来的东西仍然属于他人;你复制了一种风格,这种风格仍然属于他人。然而,“偷”是把这个想法变成你自己的想法。把别人的想法拿来自己用是“借”;理解一个想法并将其融入自己的作品,这就是他所说的“偷”。史蒂夫·乔布斯是这句名言的粉丝,苹果在他的领导下获得了成功,因为他们“偷”来了一个好主意,并其它融合和改良。

当你克隆代码时,你冒着仅仅“借”用它的风险。“借”来的代码会大量进入项目中,虽然它能够成功编译或者不抛出错误,但是它可能有你不知道的错误或恶意意图。错误地复制代码或代码复制后进行修改的风险是巨大的。事实上,大多数关于克隆代码的投诉都可以追溯到“借”用人身上。如果你不理解代码,你可能会在原本只是一个概念演示的地方留下安全漏洞。因为即使是从Stack Overflow上复制一个被复制最多的代码片段也可能有一个bug在其中。

另一方面,当你“偷”代码时,你了解代码的作用。代码的核心和它的不同寻常的思路,都将和你自己的代码无缝地融合在一起。如果你可以依靠你的记忆再写一次,那就是一个很好的“偷”的迹象;一次重写给你留下的不仅仅是一个克隆,还有一些原创的东西。

所以是的,我们要学会“偷”代码。接受它,理解它,并在自己的项目中实现它。让它成为你自己的代码。这样做可以让你变得更高效,可以改进你的项目,甚至可以充实你的简历(亦即你自己的ctrl+C和ctrl+V)。但是,如果你没有完全理解你新复制的代码和它的功能,你就有可能让你的代码变得更糟。

原文链接:

https://stackoverflow.blog/2020/05/20/good-coders-borrow-great-coders-steal/?cb=1

本文为CSDN翻译文章,转载请注明出处。

【END】

6月2日20:00,CSDN 创始人&董事长、极客帮创投创始合伙人蒋涛携手全球顶级开源基金会主席、董事,聚焦中国开源现状,直面开发者在开源技术、商业上的难题,你绝不可错过的开源巅峰对谈!立即免费围观

更多精彩推荐
☞重磅!阿里巴巴开源首个边缘计算云原生项目 OpenYurt
☞微信回应 WeTool 被封事件;支付宝小程序开放直播功能;Raspberry Pi 4 发布 8GB 版本| 极客头条
☞都无代码了,还要程序员吗?
☞附代码 | OpenCV实现银行卡号识别,字符识别算法你知多少?
☞因为一个跨域请求,我差点丢了饭碗
☞区块链的 Layer 2 扩容(Scaling)是否兑现了其承诺?
你点的每个“在看”,我都认真当成了喜欢

好的程序员“借”,伟大的程序员“偷”!相关推荐

  1. 女朋友求爱c语言程序,[转载]一个程序员写的求爱程序

    [转载]一个程序员写的求爱程序 set fso=createobject("scripting.filesystemobject") set ws=wscript.createob ...

  2. 程序人生系列谈:《程序员》带给我的启发故事

    ‍ ‍ 来源 | CSDN 博客 作者 | 叶帆科技 刘洪峰 <程序员>创刊已经20余年了, 我参加工作也已经20多年了,我专职做程序员的时间和<程序员>创刊的时间几乎一样长. ...

  3. 程序员的认知-中国程序员为什么跳槽

    2019独角兽企业重金招聘Python工程师标准>>> 一些人总是发出一些错误的声音,形成了劣胜优汰可怕的现象.他们在误导着中国,把我们的后继军训练成软件蓝领?D?D?D?D胸无大志 ...

  4. 总结过去10年的程序员生涯,给程序员小弟弟小妹妹们的一些总结性忠告

    展望未来,总结过去10年的程序员生涯,给程序员小弟弟小妹妹们的一些总结性忠告  走过的路,回忆起来是那么曲折,把自己的一些心得体会分享给程序员兄弟姐妹们,虽然时代在变化,但是很可能你也会走我已经做过的 ...

  5. python程序员搞笑段子_程序员才能看得懂的段子,内含表情包,吃饭的时候别点!...

    原标题:程序员才能看得懂的段子,内含表情包,吃饭的时候别点! 很多网友都认为程序员必定是非常古板,整天只会敲键盘的码农.其实这种看法是非常片面的.真正优秀的程序员,不仅精通程序的编写,还是某些领域的专 ...

  6. 一个C#程序员学习微信小程序的笔记

    一个C#程序员学习微信小程序的笔记 客户端打开小程序的时候,就将代码包下载到本地进行解析,首先找到了根目录的 app.json ,知道了小程序的所有页面. 在这个Index页面就是我们的首页,客户端在 ...

  7. 新手程序员如何让他快速成长?一名老程序员,谈谈对程序员的培养

    我很自豪我就是一名程序员,也希望给程序员或者前程序员们带来一点启发.纯粹个人一些想法,也许你认可我的言辞,也许你不屑我的观点,无论如何,欢迎谈谈你的看法. 让程序员做更多种类的事 为什么有人说小公司锻 ...

  8. 25岁程序员 VS 35岁程序员,太真实!

    点击上方"大鱼机器人",选择"置顶/星标公众号" 福利干货,第一时间送达! 25岁程序员 VS 35岁程序员 其中的酸甜苦辣 你中了几条 经常有人说:35岁是程 ...

  9. 调查:Java程序员最伤心,C++程序员最年老

    说起我们对编程世界现有的刻板印象,你一定听说过类似于没有人喜欢用Java编码或者使用C ++都是老人家,等等这样的话.为了分析这些刻板印象背后的真相,Trestle Technology的数据工程师写 ...

最新文章

  1. 将三维点云投影到XOZ面上
  2. vue怎么取消按回车下拉框自动下拉_八月更新第二版,小视频自动竖屏全屏播放,失效校验再次升级!...
  3. 【做题记录】AtCoder AGC做题记录
  4. Bootstrap系列 -- 41. 带表单的导航条
  5. 教师节 | 程序员都这么玩,你敢挑战吗?
  6. android 闪存软件测试,手机为什么这么卡:闪存I/O测试AndroBench
  7. android 会话 java_java – Android会话管理
  8. java hashcode 多少位_hash-为什么XOR通常在Java hashCode()中使用,而很少使用按位运算符?...
  9. SAP License:SAP顾问薪酬
  10. 使用Spine软件制作骨骼动画供Cocos2d-x使用
  11. no serializer
  12. MIPS汇编语言学习笔记27:数组
  13. 360杀毒软件无视宏病毒!
  14. php域名转向,php强制用户转向www域名的方法_PHP
  15. Matlab 乱码问题解决方法
  16. iOS 9的App Thinning方案如何节省存储空间
  17. Jmeter压力测试,个人使用总结
  18. python string类型的英文句子逆序输出
  19. 乐学成语——数据库创建(导入、打开)
  20. CCO2017 Vera and Trail Building 构造+图论

热门文章

  1. CALL TRANSACTION 和 SUBMIT 事务码之间的跳转
  2. Codeforces #105 DIV2 ABCDE
  3. UVa 116 (多段图的最短路) Unidirectional TSP
  4. (转)C#中Split用法
  5. C#编程之委托与事件(一)
  6. Linux用树形结构显示目录结构
  7. EVC编程经验点滴(一)
  8. SAS® Model Studio功能调研
  9. 代码创建listview android,android ListView 示例4 使用 SimpleAdapter 创建 ListView
  10. bag文件加载及可视化显示