热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

开发者应该负责多少代码?

当我在越来越多的组织中工作之后,我编译时候遇到的有趣问题也越来越多。严格来说,我也有了很多待办事宜。而此处的有趣并不是讽刺。这种有趣就像是你听见一个醉汉夸夸其谈他的政治观点,然后回答说

当我在越来越多的组织中工作之后,我编译时候遇到的有趣问题也越来越多。严格来说, 我也有了很多待办事宜。而此处的有趣并不是讽刺。这种有趣就像是你听见一个醉汉夸夸其谈他的政治观点,然后回答说“哦,那……很有趣”。

把这些问题放在哲学层面上真的让我很感兴趣。它们让我想去了解我从来没有想过的事情。今天我从众多问题中选出一个,然后搞清楚。这个问题是一个客户在不久之前问过我的:“开发者应该对多少代码负责呢?”

为什么要问这个呢? 好吧。是因为他们有一个值得称赞的目标。 他们有一个相当庞大的遗留代码库,并且不想那些在其上工作的人负担过重。 “我们知道我们的代码库有X行代码,所以多少开发人员可以组成一个完美的开发团队?

他们以数据驱动的方式问了一个很好的问题。然而,由于缺乏更仔细的检查,所有理由都不成立。 我今天会说出为什么会如此。下面是一些关于这个想法的问题列表。

集体代码所有权

首先,此处不谈针对集体代码所有权的异议。历史上,应用程序开发的经理出于特殊的目的往往将软件工作和体力劳动做对比。

有一堆需要挖的洞? 分配给每个团队成员一些挖洞的任务。有一堆需要编写的代码? 分配给每个团队成员需要编写的代码段。

当你意识到代码与挖洞是不同的,代码块不是商品的时候,你就要准备好应对麻烦事了。也就是说,你不能拿它们做互换交易。所以当你对代码进行了划分,刚好碰上编写 X 模块的人请了两个星期假,那你只是能把任务搁置,直到那个人回来。

个人代码所有权也会带来其他问题,但往往是对业务影响最大的。有人称之为“公共要素”。但是无论你叫它什么,当你开始谈论团队成员对现有代码的“负责”时,你应该鼓励此类行为。 因团队本应该对代码库负责。 仅此而已。

代码量意味着什么呢? 无所谓?

对于那些年纪比较大的.NET开发者来说, 你可能会把你的编程历史分为"BL"和"AL". 即"Linq前"和"Linq后"。

在 Linq 出现之前, 你写了大量的指令性的代码,,遍历嵌套循环直到找到你想要的对象。而Linq一经问世, 所有这些都变成了声明式的代码。但它不是通过一对一的智能海量映射做到的。它是将你的冗长的就像快要爆炸了的中子星一样的指令性代码,分割成一系列更小的部分。

通过这些,我们知道了代码量在不同的语言、开发者甚至语言的不同版本之间,都会有巨大的差异。因此,"How Much" 作为一个数值指标变得相当不稳定,以至于有很少的可度量的值.

从商业的观点看, 代码就像库存, 它提供了商业可能性, 但是它放在那儿,就是你的负债。你希望开发者用尽可能少的代码完成一个功能。而比较讽刺的是,有些开发者们更趋向于为每一个功能写尽可能多的代码,他们就应该为"最少代码"负全责。毕竟有时候, 多不一定更好。

代码的不确定性

我提出的第三个也是最后一个反对意见是关于代码不确定性的。这里,我指的是给定文件或代码段的更改频率。

要理解代码的不确定性会在哪产生分歧,请考虑两个极端。首先,考虑一个稳定的、被充分考虑的模块,它包含了一百万行代码。每隔3-4年,就会出现一些新的政府监管规定,需要对这里或那里进行一些细微的调整,但除此之外,它如产品链上的梦幻一般运行良好。

另一方面,考虑一个10,000行应用程序。但是这个应用程序有各种各样的运行时问题。这里,为了更说明问题,假定持股人在不断改变着他们对软件行为的想法,导致大量粗制滥造。

对于这两个代码库,您完全可能将100万行的代码库交予1个开发人员维护,而你需要一整个团队来为第二个代码库工作也是完全可能的。尽管后者的代码库的大小是前者的1%,这依旧是有理可据的。

我提供这个例子来说明一个重要的观点。光用代码的行数来作为维护的依据是欠妥的。因此,仅仅使用代码行数来评估维护计划会成为悲伤的故事。

根据代码库对团队进行评估

那么,你如何根据代码库来划分一个团队大小?如果不可行,那么开发人员应该负责多少代码,或者说“开发人员应该承担多少责任?”

我将给出一个既简单又难以衡量的方案:开发人员应该承担多大的责任?基于这点考虑,可以让代码变得更加规范。

在敏捷(Agile)开发的世界里,这一思路产生了故事地图(story mapping)和计划活动(planning activities)。将软件的目标划分为待办事项列表中的特性,然后让团队对这些特性进行分析处理。如果团队在业务上进展过慢,则表示你的团队需要壮大。如果人们无所事事,说明你的团队人员冗余。

在自顶向下计划/瀑布模型的世界中,会呈现出一种类似的动态现象,而你所能做的就只是算算会在什么时候先于计划完成(哈,就是这样)或是开始落后于计划。先于计划,那就是团队人数太多了,落后于计划,就是人数还不够。

诚然,你得通过计算和观察软件所实现的功能是否能跟上业务需求的演进步伐,才能估量出开发人员所要承担的责任范围。



推荐阅读
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 解决微信电脑版无法刷朋友圈问题:使用安卓远程投屏方案
    在工作期间想要浏览微信和朋友圈却不太方便?虽然微信电脑版目前不支持直接刷朋友圈,但通过远程投屏技术,可以轻松实现在电脑上操作安卓设备的功能。 ... [详细]
  • Python入门:第一天准备与安装
    本文详细介绍了Python编程语言的基础知识和安装步骤,帮助初学者快速上手。涵盖Python的特点、应用场景以及Windows环境下Python和PyCharm的安装方法。 ... [详细]
  • 在Java中,this是一个引用当前对象的关键字。如何通过this获取并显示其所指向的对象的属性和方法?本文详细解释了this的用法及其背后的原理。 ... [详细]
  • 2018年3月31日,CSDN、火星财经联合中关村区块链产业联盟等机构举办的2018区块链技术及应用峰会(BTA)核心分会场圆满举行。多位业内顶尖专家深入探讨了区块链的核心技术原理及其在实际业务中的应用。 ... [详细]
  • 本文详细介绍了C语言中的指针,包括其基本概念、应用场景以及使用时的优缺点。同时,通过实例解析了指针在内存管理、数组操作、函数调用等方面的具体应用,并探讨了指针的安全性问题。 ... [详细]
  • 本文介绍如何在Java项目中使用Log4j库进行日志记录。我们将详细说明Log4j库的引入、配置及简单应用,帮助开发者快速上手。 ... [详细]
  • 本文详细记录了在银河麒麟操作系统和龙芯架构上使用 Qt 5.15.2 进行项目打包时遇到的问题及解决方案,特别关注于 linuxdeployqt 工具的应用。 ... [详细]
  • Linux设备驱动程序:异步时间操作与调度机制
    本文介绍了Linux内核中的几种异步延迟操作方法,包括内核定时器、tasklet机制和工作队列。这些机制允许在未来的某个时间点执行任务,而无需阻塞当前线程,从而提高系统的响应性和效率。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 深入解析TCP/IP五层协议
    本文详细介绍了TCP/IP五层协议模型,包括物理层、数据链路层、网络层、传输层和应用层。每层的功能及其相互关系将被逐一解释,帮助读者理解互联网通信的原理。此外,还特别讨论了UDP和TCP协议的特点以及三次握手、四次挥手的过程。 ... [详细]
  • 探索如何使用公共数据集为您的编程项目提供动力。无论您是编程新手还是有经验的开发者,本文将为您提供实用建议和资源,帮助您启动并运行一个创新的数据驱动型项目。 ... [详细]
  • 《数字世界的奥秘》是由著名计算机科学家Brian W. Kernighan撰写的一本科普读物,深入浅出地揭示了计算机和通信系统背后的原理。无论是计算机初学者还是非专业人士,都能从中获得宝贵的知识和启发。 ... [详细]
author-avatar
咖喱2502894907
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有