InfoQ

InfoQ

新闻

我的书签

登录注册 以永久保存书签。

该内容已经被标记书签!

标记书签错误,请重试!

代码集体所有制的弱点在哪里?

作者 Mark Levison 译者 郑柯 发布于 2008年5月6日

领域
过程 & 实践
主题
协作 ,
敏捷
标签
教练和指导 ,
故障解决

敏捷社区中许多人采取“代码集体所有制”实践有一段时间了,这段时间内我们确实发现了一些问题。

根据众多书籍的作者、ThoughtWorks首席科学家Martin Fowler的说法, “代码集体所有制(简称CCO)”抛弃了个人拥有代码所有权的想法。实际上,代码是由整个团队所有的,团队中任何人都有权对其修改。常为人提到的好处包括:增加了“卡车因素”、负载均衡(瓶颈最小化)和使代码向所有人开放。此外,Wiki的发明人、AboutUs公司CTO,Ward Cunningham指出CCO可以增加开发工作的自豪感,因为整个团队都可以看到一个人的全部开发工作,而不是仅看到一个很难理解的API,而此人其他的努力都隐藏于其后。

Software Development和Computer Language的前编辑Larry O’Brien认为:即使有这么多好处,CCO还是有一个很大的缺陷——它会使得管理层无法发现恶劣的程序员。Larry有两个核心观点:

  • 恶劣的程序员并不是工作速度慢的好程序员。他们在主动地对团队的生产力起到反作用。”
  • CCO会隐藏恶劣的程序员,因为好程序员们会发现这些人制造的问题并解决掉;管理层无法知道恶劣的程序员在拖团队的后腿。

摩托罗拉全球电信解决方案部门(Motorola Global Telecom Solutions Sector)的首席软件工程师Brad Appleton已经见过很多案例,在这些案例中,CCO被降级为“无人所有制”,没有人承担责任。实际上,他建议使用 “代码管事人(Code Stewardship)”机制(Martin Fowler称之为“弱代码所有制[Weak Code Ownership]”),他说:

代码管事人既是监督者又是指导者,负责监督指导模块和类中的相关知识。代码管事人的工作不只包括担任并发访问代码的保卫,还要保证代码(在概念上和结构上)的完整性和一致性,以及向他人广泛传播知识及其专业技能。

所以“代码集体所有制”可以起到很好的作用,不过必须要保证它不会堕入“无人所有制”的混乱状况(无论通过纪律保证,还是使用“代码管事人”),而且要注意发现有意拖团队后腿的恶劣程序员。

查看英文原文:Are there weaknesses with Collective Code Ownership?

译者 郑柯 InfoQ中文站总编。做过开发,当过PM,干过销售,搞过市场,最终还是回到媒体。实用的理想主义者,相信:每天改变一点点,这个世界会更好。

CCO会隐藏恶劣的程序员? 发表人 小刀 凉粉 发表于
Re: CCO会隐藏恶劣的程序员? 发表人 小刀 凉粉 发表于
Re: CCO会隐藏恶劣的程序员? 发表人 Yi Yuan 发表于
Re: CCO会隐藏恶劣的程序员? 发表人 小刀 凉粉 发表于
随之而变 发表人 长 白条 发表于
BOSS可能只知道速度吧 发表人 withyou gakaki 发表于
  1. 返回顶部

    CCO会隐藏恶劣的程序员?

    发表人 小刀 凉粉

    如果一个程序员代码写的坏,那他的pair,乃至整个团队会很快知道这一点啊,怎么会被隐藏起来呢?

  2. 返回顶部

    随之而变

    发表人 长 白条

    敏捷之精髓在适应变化
    应该在 “集体所有制”与“承包责任制”间变化

  3. 返回顶部

    Re: CCO会隐藏恶劣的程序员?

    发表人 小刀 凉粉

    英文站也有这样的回复:



    With collective ownership, the team as a whole will very quickly discover who's harmful. This also turns out to be a much more reliable judgment than any code metrics yet invented.

  4. 返回顶部

    Re: CCO会隐藏恶劣的程序员?

    发表人 Yi Yuan

    但是boss不一定知道啊

  5. 返回顶部

    BOSS可能只知道速度吧

    发表人 withyou gakaki

    感觉还是很有用的,以前项目里很多东西都是我一个人做的什么chart图之类,后面的人等我离开之后都不会做了。
    如果所有人都知道这些代码的含义,那公司就不会被一个人的离去而拖垮

  6. 返回顶部

    Re: CCO会隐藏恶劣的程序员?

    发表人 小刀 凉粉

    每个人都有一张嘴两只手,如果一个团队中n个人都认为某人很恶劣,但是boss却不晓得,你觉得这会是CCO带来的问题么?

深度内容

大规模视频网站的计费与流量管理

本次分享将会就大规模视频网站的计费与流量管理这个话题,从操作层面细细进行讲解和分析,为系统工程师们揭示平日里我们没有关心的另一些内容。同时也希望本次分享能揭示行业中的一些“潜规则”,让互联网行业的流量与带宽管理更为开放与简洁。
本次演讲视频录制于QCon杭州2011

专访Jeffrey Richter:Windows 8是微软的重中之重

Jeffrey Richter以其多本Windows核心技术的经典著作而闻名,同时,他深入掌握微软的.NET等一系列核心技术,2012年1月,Jeffrey Richter在北京接受了InfoQ中文站的专访,谈到Windows 8和WinRT编程,并就异步编程、Windows编程中的可扩展性、性能和安全性方面给出自己的建议。

应用云平台的可用性——从新浪SAE看云平台设计

云计算平台的可用性,相比传统互联网服务而言,更加复杂和困难,也更具有挑战性。本文借助新浪SAE云平台为读者讲述了云平台可用性的定义、如何打造高可用的平台,以及对云计算的用户提出了建议。

JVM定制改进 @ 淘宝

淘宝高度重视Java平台的健康发展,组建了一个团队专注于Java平台的底层部分的性能、功能与稳定性改进;工作主要基于OpenJDK中的HotSpot VM开展,其中一些通用的功能随后也会逐渐反馈给OpenJDK社区。希望能与使用Java平台开发应用的大家交流经验。
本次演讲视频录制于QCon杭州2011

"伤得起"的云计算应用——对云端应用之架构的思考

2011年4月21日至22日是值得云计算从业者纪念的日子。Amazon的IaaS服务出现故障,导致许多商业网站的服务中断,影响非常严重。作为云计算用户,我们需要思考的是,如何保证即便在云服务不可用的情况,我们的应用架构仍然能够屹立不倒?本文正是站在云计算用户的角度试图探讨这一问题。

让交付的速度跟上思考的速度

12人的技术团队,4组刀片服务器,每月20亿的访问量,每日1次准时部署,99.9%的可用性。这可能吗?当然。想知道如何做的吗?百姓网将与您分享他们在DevOps实践过程中的经验和技巧。
本次演讲视频录制于QCon杭州2011

架构之路——穿行在产品和业务之间

篱笆作为一家起源于社区的电子商务公司,反映到技术层面就是同时要面对产品和业务,以及经营战略的变化调整。如何在产品和业务的夹缝之间完成技术架构的抽象与平衡,寻找更有效的价值定位,这当中有些经验教训和个人感悟愿与众人分享。
本次演讲视频录制于QCon杭州2011

特性注入:成功三部曲

本文将对特性注入以及相关方法做一个扫盲性的介绍。我们会解释这个框架的关键要素,并附上实例来证实它们。为了让文章保持相对较短,我们不会深入到某个工具或方法中,而是会给出一些参考资料,以便大家做进一步的研究。