写点什么

代码重用的价值被严重高估?

  • 2007-07-29
  • 本文字数:1235 字

    阅读完需:约 4 分钟

Carl Lewis 最近发现了 Dennis Forbes 的一篇虽然有点老但仍然很有意思的文章,文章的主题是关于衡量代码重用。 Lewis 详细讲述了在 Forbes 的 Blog 上众多具有争议性的概念之一:与代码是资产的普遍观点相反,如果代码脱离了组织机构考虑创建这些代码时的原因的直接背景,代码本身而言并没有什么价值。Forbes 还声称,如果没有明确地为通用性而设计的代码,尝试在多个项目间进行代码重用,甚至只是在同一机构里也是困难重重的。

Forbes 谴责许多内部开发小组现在的倾向,他们花费大量时间来构建可在多个项目间重用的所谓的内部框架和库:

这样的代码你积累得越多,就越是需要依赖于你现有的开发人员(并且这些只适用于某组织或是开发小组的资料也越来越占用他们的头脑),同时也越难让新加入的开发人员上手。这样的框架和库对于新员工来说通常有极陡峭的学习曲线,而在缺乏文档的情况下更甚。如果没有经过有效的重构,代码被重用的可能性也是很小的(因为这些代码是以恣意肤浅的方式编写出来的,而不是真正为重用而设计的……)

……每个组织都有必要扪心自问的是,他们所谓的“可重用代码”到底有什么值得称道的 a 价值,有什么实际的地方让竞争对手和新参与者们会为此买帐吗?对于绝大多数的案例来说,答案是价值为 0,对手们甚至认为连 0 块也不值。在这一行里代码窃贼格外罕见(虽然我们身处一个刻录 DVD 和 U 盘的时代),因为大多数的代码,除了整个行业都广泛使用的框架和库,脱离了特定的项目和开发组环境的情况下是完全没有任何价值的。尝试在其它项目中使用这些代码的话还不如根本没有的好。

Forbes 总结道,设计和开发一个恰当抽象并通用的框架所花费的精力远比一次性的解决方案要多,因为在分析重用代码所带来的好处时,很少把开发者用于接受复杂的新框架所花费的时间和代价计算在内,所以这是实际发生的代码重用比起通常想象中的要少得多的原因。值得注意的是,Forbes 并没有一概反对重用代码和框架,他反而很支持作为工业标准库的可重用代码。实际上,Forbes 提倡采纳已被广泛应用的行业标准框架(如开源框架),因这些框架都有恰当的抽象和清晰的封装边界从而可作为复杂的内部开发框架的替换品。

在 Carl Lewis 的文章中他强调了 Forbes 的多数代码库无价值的观点。Lewis 和我们分享了他曾遇到的一个例子,某公司对他们自己的代码极度自信,并称他们的代码为“需小心守护之物”。当 Lewis 为了他们代码不外泄的前提而飞越数千公里到达现场时,发现他们一直以来小心翼翼保护的代码库实际上非常糟糕。从这些类似的例子中,Lewis 相信“在多数情况下,[代码失窃的] 风险发生的几率远比一般想象中要低”,所以在有意义的情况下企业不应该害怕把代码共享出来。

Lewis 和 Forbes 给我们举了很有意思的现实例子,告诉我们如何看待我们的代码资产,如 Lewis 所说:

如此困难又需花费如此多精力的东西竟然只有如此小的价值,听起来似乎有违常理。我想这就是为什么有那么多公司喜欢夸大他们的代码的价值的原因吧。

英文原文链接: Code reuse highly overrated?

2007-07-29 04:351342
用户头像

发布了 27 篇内容, 共 11.1 次阅读, 收获喜欢 15 次。

关注

评论

发布
暂无评论
发现更多内容

这可能是 Markdown 写微信公众号的一款神器了!

JackTian

效率工具 markdown markdown编辑器 markdownnice 神器

推荐几款有意思的小众App(05.30)

静陌

产品 App

如何衡量产品需求效果

黄大路

产品经理 产品设计 运营

Linux下程序出问题不要慌,资深程序员教你6招搞定!

程序员柠檬

Linux 程序员 后台开发

k6新崛起的性能测试工具

风中之心

DevOps 性能 性能测试

2020年亚洲南京大数据产业展览会

南京专业智博会

展览会 论坛会 博览会 智博会

2020亚洲南京第十三届人工智能机器人服务展览会

南京专业智博会

展览会 论坛会 博览会 智博会

2020年南京第十三届智慧停车展会

南京专业智博会

展览会 博览会 智博会 展览会论坛会

2020南京第十三届智慧工地装备展览会

南京专业智博会

展览会 论坛会 博览会 智博会

2020亚洲智能家居全屋智能展会-南京站

南京专业智博会

展览会 论坛会 博览会 智博会

PageHelper

BitSea

10分钟白嫖我的常用的在线工具网站清单

JavaGuide

设计 在线工具 工具类网站 PDF

不忘初心,继续努力

一周思进

ARTS 打卡计划

你真的清楚 Nginx 指令的规则吗?

子杨

nginx 运维

原创 面试官:你说对MySQL事务很熟?那我问你10个问题

程序员柠檬

MySQL 数据库

使用 PCA 进行降维可视化,了解特征分布

黄大路

数据挖掘 数据分析 可视化

2020年南京第十三届物联网应用展览会

南京专业智博会

展览会 论坛会 博览会 智博会

github看代码效率提高10倍!因为用了sourcegraph这个工具

程序员柠檬

GitHub 程序员 效率工具

Jupyter最佳实践

pydata

分布式锁🔒是个啥❓ 其实就这么点事

山中兰花草

Java redis 后端 分布式锁 开发

Wireshark的使用与数据分析(一)

姬翔

面试造飞机系列:说下微服务接口设计原则?

程序员柠檬

分布式 微服务 后端 架构设计

游戏夜读 | 记忆里的老游戏

game1night

Markdown 几行字符就可以生成思维导图了!

JackTian

markdown 思维导图 markdown语法 markdown编辑器 Markmap

如何优雅地实现泛型类的类型参数化

KAMI

Java 编程 反射 泛型

原创 | 使用JUnit、AssertJ和Mockito编写单元测试和实践TDD (十二)编写测试-简单测试

编程道与术

Java 编程 TDD 单元测试 JUnit

思维模型 - 概念篇

石云升

学习 高效 思维模型 决策

Java 底层基础笔记(一)硬件

奈何花开

Java Linux 计算机基础

ARTS打卡-01

Geek_yansheng25

ARTS 打卡计划

ARTS-week-1

saddamwilson

ARTS 打卡计划

用大数据分析了一线城市1000多份岗位招聘需求,告诉你如何科学找工作

程序员柠檬

Python 数据分析

代码重用的价值被严重高估?_架构_Mark Figley_InfoQ精选文章