写点什么

只加两行代码,为什么要用两天?

  • 2020-07-22
  • 本文字数:2138 字

    阅读完需:约 7 分钟

只加两行代码,为什么要用两天?

这个需求很简单,怎么实现我不管

“帮我写个电商网站,就淘宝那样的,预算 3000 够不够?不够还可以再加点儿。”

“帮我写个百度那样的搜索引擎,就一个输入框应该花不了多久吧?”

“我这个需求稍微复杂一点,帮我写一个随手机主题颜色而变色的智能后盖,钱不是问题。”

……


不管你是互联网公司的正规军,还是兼职外包的开发者,你或多或少都会遇到各种各样来自产品、客户、老板们的花样繁多的需求,而且他们都一致认为:这个需求很简单。


可事实果真如此吗?


“只加了两行代码,为什么你要用两天时间?”


这种问法看似合理,但背后却隐藏着几种荒谬的思维方式:


  • 代码行数 = 工作量

  • 代码行数 = 价值

  • 代码行之间没有区别,各自对等


很明显,以上三条都是胡说八道。


开发者面对这样的指责,翻白眼之余却也不免委屈,软件开发是把物理世界映射到虚拟世界的一种神奇魔法,回顾我们做出的变更,有太多理由能解释这两行代码为什么要用两天时间。


因为问题报告对于重现方法的描述不够明确。


有时候,我们需要耗费几个小时才能可靠地重现某些问题。遇到这种情况,有些开发人员会立即与问题上报者取得联系,要求对方提供更多详细信息。但也存在一些开发人员讨厌修复 Bug,于是信息不足就成了甩锅的好办法。


因为报告的问题与功能有关,而我对功能不太熟悉。


这里可能涉及某些开发者很少使用的功能,所以对相关细节真的不太熟悉。为此,开发者需要耗费更长的时间理解功能的使用方式,特别是这项功能性 bug 与软件交互的具体流程。


因为我花时间去调查了引发问题的真正原因,而不止流于表面症状。


如果某些代码引发了错误,那直接把它打包在 try…catch 语句中即可有效抑制住错误。没错误,也就没问题了,是吗?当然不是。对有责任心的开发者来说,掩盖问题与解决问题是两码事。掩盖错误很容易引发其他意料之外的副作用。我可不想在未来某个关键时刻再次被同样的错误困扰。


因为除了上报的重现步骤之外,我还调查了其他可能引发同一问题的情况。


一组重现步骤虽然能够轻松让错误再次出现,但往往不足以揭示引发错误的深层次原因。只有找到这种根源性因素,同时研究解决问题的所有可行方法,才算是真正有价值的分析洞见。这可能涉及代码的实际运作方式,可能是其他位置存在其他需要解决的问题,或者是存在某些代码不一致状况(导致某一代码路径中出现错误,其他路径则不会出错)等等。


因为我花时间验证了代码的其余部分是否会受到类似问题的影响。


如果错误源自某项 bug,那么代码库内的其余位置应该也会存在相同的错误。既然有用户上报了,最好是全面检查一下。


因为在发现错误根源时,我希望以最简单的方法加以解决,保证将引入副作用的风险控制在最低水平。


因为我彻底测试了这项变更,并确保其能够解决不同代码路径下的同一问题。


我不想把修复测试这种麻烦事推给其他人。我不希望之后再出现类似的错误,所以我投入了巨大的心力,保证问题得到彻底解决。上下文切换既复杂又枯燥,我希望自己的工作能让专职测试人员再也不用进行本质上“完全相同”的变更。


还有什么比修复 Bug 更烦人的?那就是反复修复同样的 Bug。你只看到了我增加了两行代码,却没看到我在背后分析为什么要加这两行代码,这两行代码为什么要以这种方式实现。

一天就写几行代码,时间都在干嘛?

不少团队的绩效考核指标都曾被爆出过是以“代码行数”为主,部分测试人员则以查杀“Bug”数为依据,各大互联网大厂也都曾把团队动辄千万甚至上亿行代码作为品宣卖点。


这给了外界一个错觉,似乎代码行数成为了一个程序员技术能力、工作产出的万金油式衡量标准。可写得多,就代表写得好吗?那密密麻麻的 if…else 冲击波莫非还能类比成写文章时的排比句式,给人一种气势恢宏之感?


Linus 看了想打人。


事实上,一个程序员的工作产出跟代码行数并不是强相关的,程序员的工作时间也并不仅仅局限在写代码上。


根据国外调研机构 ActiveStates 去年的一份调查报告,包括美国、中国在内的 80 多个国家、上千名开发者样本结果显示:


六成开发者日均编程时间不足 4 小时。



在 1250 份调查样本中,38.8% 的受访者每天只花 2-4 小时编程。这与 2018 年的调查结果相似,37% 的受访者每天花 2-4 小时编程。相比之下,27.92% 的受访者每天花 5-7 小时编程,而 2018 年的调查结果显示,31% 的受访者每天花 5-7 小时编程。


最让人惊讶的是,2019 年总计有多达 61.52% 的受访者花 4 小时甚至更少的时间编程,而在 2018 年,只有 51% 的受访者花 4 小时或更少的时间编程。10.56% 的受访者花 8 小时或更长时间编程,而 2018 年这一比例为 19%,几乎减少了一半。


开发者们花在写代码的时间上越来越少,那么时间都去哪儿了呢?



44% 的受访者表示,他们必须把时间花在各种各样的活动上,包括会议、测试、维护,甚至是社交活动。花费时间最多的单一活动是软件设计 / 架构,占 11.36%,其次是参加 standups/ 会议,占 8.24%。


在中国,这些开发者们可能还需要花费大量的时间在日志、周报的撰写上:


我这几行代码体现了怎样的社会情怀,包含了我哪些精华的技术与商业思考,最大程度地实现了客户价值,满足了用户需求,给团队留下了宝贵的技术财富,为数字化经济的实现添砖加瓦,拉通了团队,对齐了目标,解决了痛点,赋能了行业,复盘了人生。我们程序员真是太厉害啦!


你说,花两天时间是不是还算我效率高了呢?


2020-07-22 13:004000
用户头像
小智 让所有人认同的文字称不上表达

发布了 410 篇内容, 共 410.3 次阅读, 收获喜欢 1986 次。

关注

评论 6 条评论

发布
用户头像
因此对产品经理来说,有开发经验应该算是入门要求,否则如上。。。。
2020-07-22 22:33
回复
用户头像
能发起这种对话的.两行业务代码能用多久时间
2020-07-22 13:41
回复
用户头像
“帮我写个电商网站,就淘宝那样的,预算 3000 够不够?不够还可以再加点儿。”


“帮我写个百度那样的搜索引擎,就一个输入框应该花不了多久吧?”


“我这个需求稍微复杂一点,帮我写一个随手机主题颜色而变色的智能后盖,钱不是问题。
……

我觉得这表述的没有任何问题.
1. 淘宝那样的,猪八戒上面3000块钱
2. 套用搜索引擎
3. 钱都不是问题了.还有什么是问题?
展开
2020-07-22 13:39
回复
2020.7.22 加入
2020-07-23 10:07
回复
nil回复辰九
可笑至极

2020-07-23 15:22
回复
用户头像
太真实了。好像就是产品口头禅
2020-07-22 13:04
回复
没有更多了
发现更多内容

如何在 TiDB Cloud 上使用 Databricks 进行数据分析 | TiDB Cloud 使用指南

TiDB 社区干货传送门

基础到高级涵盖11个技术,Alibaba最新出品711页Java面试神册真香

收到请回复

Java 大数据 架构 编程语言 语言 & 开发

Go-Excelize API源码阅读(十四)——GetSheetFormatPr

Regan Yue

开源 源码刨析 Go 语言 8月日更 8月月更

20万字的《Kafka运维实战宝典》PDF现在免费下载了

石臻臻的杂货铺

大数据 kafka

TiDB 和 Golang 的简单 CRUD 应用程序

TiDB 社区干货传送门

当内卷风波及代码领域,看Alluxio将会采取怎样的块分配策略

Alluxio

腾讯 存储 Alluxio block 8月月更

HarmonyOS Connect FAQ第四期

HarmonyOS开发者

HarmonyOS

利用现有数据库管理系统创建一个安全的分布式数据库集群

亚马逊云科技 (Amazon Web Services)

大数据 分布式 Tech 专栏

故障处理 | DM 搭建 MySQL 8.0 同步链路报错:code=26005

TiDB 社区干货传送门

安装 & 部署 TiDB 源码解读

TiDB 和 Java 的简单 CRUD 应用程序

TiDB 社区干货传送门

TiFlash Proxy 模块介绍

TiDB 社区干货传送门

什么!阿里最新版Spring Cloud Alibaba项目文档,竟将重要组件弃用

收到请回复

Java spring 阿里巴巴 面试 spring-cloud

魅族高校新生充电计划进行中,直播课让科目一新生直呼厚道

极客天地

采访22年第一批秋招上岸的同学后,我整理了这份Java面试手册

Java面试那些事儿

Java 编程 程序员 架构 面试

手把手教你实现 TiFlash 向量化函数丨十分钟成为 TiFlash Contributor

TiDB 社区干货传送门

离线部署系列文章之二:TiDB集群升级(5.3.0->5.4.2)&缩扩容 TiDB Server、PD、TiKV、TiFlash

TiDB 社区干货传送门

版本升级 集群管理 管理与运维 安装 & 部署

多并发下线程创建、释放的阻塞问题

TiDB 社区干货传送门

大数据训练营毕业总结

Geek_Q

希捷亮相OCP China Day 2022,与生态伙伴共话绿色存储之道

极客天地

如何让 TiDB 集群管理“更省心”?TiUniManager(原 TiEM)使用教程来了

TiDB 社区干货传送门

某站下载量过W的近4000页“Java面试合集”号称大厂面试零门槛

收到请回复

Java 程序员 面试 金九银十

离线部署系列文章之一:TiDBv5.3.0集群部署&源码部署 Haproxy v2.5.0

TiDB 社区干货传送门

实践案例 版本升级 管理与运维 安装 & 部署 扩/缩容

PingCAP Clinic 服务:贯穿云上云下的 TiDB 集群诊断服务

TiDB 社区干货传送门

膜拜阿里!首次发布「10亿级并发系统设计文档」(内部绝密)

退休的汤姆

阿里 面经 Java工程师 秋招 并发系统设计

对话ACE第五期:到底什么才是真正的HTAP?

OceanBase 数据库

如何在企业数字化团队内部实现数据分析建模成果的结构化整合沉淀

ModelWhale

工作流 数字化转型 数字化 案例分享 提高效率

传统堡垒机数据可以迁移到云堡垒机上吗?方式有哪些?

行云管家

云计算 网络安全 堡垒机

云堡垒机主要针对运维过程中的什么进行管理和审计?

行云管家

运维 堡垒机 IT运维 云堡垒机

一对一直播软件——如何实现音视频传播?

开源直播系统源码

软件开发 直播系统源码 一对一语音聊天软件 语音直播系统

五天玩转EMAS Serverless

云端explorer

云计算 Serverless emas

只加两行代码,为什么要用两天?_语言 & 开发_小智_InfoQ精选文章