你只写了两行代码,为什么要花两天时间?

2024-04-27 06:48

本文主要是介绍你只写了两行代码,为什么要花两天时间?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文 | https://www.mrlacey.com

作者 | Matt Lacey

我花了两天时间,写了两行代码。

对于真正的程序员来看,这可能是一个合理的事情,但背后不理解程序员的人,往往会做出了一个可怕的假设:

  • 代码行数 = 程序员的努力

  • 代码行数 = 程序员的价值

  • 所有代码都是等效的

我想对这些人说,“别瞎猜了,这都是错的!”

那么,为何看似简单的问题,要花费两天时间才能修复呢?

1

因为有些人上报问题时,对描述「如何复现问题」写得十分模糊。有时我们要花了几个小时才能复现问题。收到报告时,一些程序员会立即反馈给上报问题的人,要求他们提供更多的信息,才能研究问题是如何产生的。

而有些程序员不喜欢修复 bug,他们会以信息不完整,无法复现问题为借口,拖延修复进度。

我知道上报问题可能很麻烦,对此我向上报问题的人表示感谢。所以我尽可能在用已知信息来修复 bug,避免给上报的人增加沟通成本。

2

因为上报的问题与自己负责开发的功能不相关。 

有时,与发现的错误相关的功能是我很少使用的,或者不是我负责开发的。这意味着,我要花了更长的时间来理解这个功能是如何实现的,以及它与错误是如何关联的。

3

因为我需要花时间调查问题的真正原因,而不是仅仅看表面上的错误。

通常,如果某些代码抛出错误,则可以将其包装在 try...catch 语句中来避免错误。

如果这样没有错误,就是没有问题吗?不,对我来说,让问题不出现与解决该问题是不同的。这种方式规避错误很容易导致其他意外的副作用。我不想在将来再与这次问题打交道。

4

因为我需要研究「是否存在其他方法可以复现相同的问题」,而不是按步骤简单地复现问题。

可能有其他方法让我们找到 bug 带来的更深层问题。找到问题的根本原因,并研究解决方法,这才可以避免类似 bug 的产生。

5

因为我需要花时间验证代码的其他地方是否会受到影响。

如果某段代码导致了错误,那么在代码库的其他地方也可能发生相同的错误,此时是检查的好时机。 

6

因为当我需要找到问题的根源时,我寻求最简单的方法来解决它,而这种方法将带来最小的副作用风险。

我并不想只以最快的方案来解决问题,我想要的修复方案是在将来不会引起混乱或其他 bug。

7

因为我对自己所做的更新会进行彻底的测试,并验证所有受影响的路径保证没有问题产生。

我不想依靠别人来测试我所做的更新,因为我不希望之后再发现错误。再次重新思考之前的方案既耗时又费力,所以我会尽可能避免让测试的人再次上报类似的问题。

其实我不喜欢修复 bug。其中一个原因是,这些 bug 是自己必须要面对的错误。另一个原因是,我更喜欢在新功能的开发上,有哪个程序员会喜欢把时间耗在修复 bug 上呢?

问:如果想逼疯一个程序员,还有什么比让他马上修复一个 bug 更有效的呢?

答:让他反复修复同一个 bug。

我愿意会花时间确保任何一个 bug 在出现后会被完全修复,这样就不需要再一遍一遍地检查、修复和测试了。

同样也避免和和领导、产品经理、测试人员之间的相互伤害了。

程序员改善代码质量的 101 个方法

本书介绍了软件开发领域 101 个重要的编程原则,涉及编程中的永恒真理,指导方针,编程思想,程序员的视角、习惯和工具,以及编程的反模式等内容。

书中以“这个原则是什么”“为什么要遵循这个原则”“具体应该怎么做”为中心,对各个原则进行介绍,简明扼要,通俗易懂。这些原则凝聚了前人的智慧,经过了历史的考验,是指导程序员改善代码、进一步提升编程能力的实用指南。

本书适合各层次软件开发人员和项目管理人员阅读,也可作为高等院校计算机相关专业师生的参考读物。

图灵官方小店

享受正版低价折扣


这篇关于你只写了两行代码,为什么要花两天时间?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/939785

相关文章

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

python处理带有时区的日期和时间数据

《python处理带有时区的日期和时间数据》这篇文章主要为大家详细介绍了如何在Python中使用pytz库处理时区信息,包括获取当前UTC时间,转换为特定时区等,有需要的小伙伴可以参考一下... 目录时区基本信息python datetime使用timezonepandas处理时区数据知识延展时区基本信息

Python的time模块一些常用功能(各种与时间相关的函数)

《Python的time模块一些常用功能(各种与时间相关的函数)》Python的time模块提供了各种与时间相关的函数,包括获取当前时间、处理时间间隔、执行时间测量等,:本文主要介绍Python的... 目录1. 获取当前时间2. 时间格式化3. 延时执行4. 时间戳运算5. 计算代码执行时间6. 转换为指

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求