先占个窝,牛年开门篇,立春首献,必须牛.原始地址,java也随时更新.
http://www.trydofor.com/a9w3-auhome/trydofor/article/2009/0204145037/body.htm
活力门之软件开发模式
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
- 作者:臭豆腐[trydofor.com]
- 日期:2009-02-04
- 授权:署名-非商业-保持一致 1.0 协议
- 声明:拷贝、分发、呈现和表演本作品,请保留以上全部信息。
0. 文档目录
^^^^^^^^^^^
[[<=$INDEX]]
1. 活力门之软件基地
^^^^^^^^^^^^^^^^^^^
活力门公司(Livedoor)总裁堀江贵文是日本经济产业界的风云人物,
2004年在福布斯排名列日本49位,曾被认为是日本创业者的楷模.
livedoor.com于2000年在东京所创业板上市,跻身日本三大门户网站行列.
截至2005年9月底,该公司已经拥有44家子公司,销售额达784亿日元.
以堀江的经历为蓝本的日剧"坠入情网:我成功的秘密"在富士电视台开播.
当当网上有中文版的:"堀江贵文和他的活力门"
堀江谢绝日本首相小泉纯一郎让他参加众议院议员竞选的邀请,
以无党派人士身份参加激烈的竞选.最终一个商界精英倒在了政治战场上.
2006年初,"活力门事件"轰动世界,重创日本经济.
英极软件(大连)作为活力门子公司,中国唯一软件开发基地,于2006年获得
"2006中国最具影响力创新成果100强"殊荣.
活力门金融集团公司(株式会社ライブドアフィナンシャルホールディングス,
Livedoor Financialholdings Inc.) 是活力门的一个重要子公司.
全全对应其设计,开发,运营,维护的唯一项目组就是英极的Credit.
和Livedoor时代一样,Credit一直做着这唯一的一个项目,不同的只是不叫
LivedoorFinance.如果Livedoor是成功的,英极是成功的,那么Credit就是成功的.
2007年10月起,我有幸接管整个Credit项目,成了有头衔和最大职责的战士.
战士就是一线开发人员,项目组都是战士,代码面前人人平等.
摸爬滚打,痛定思痛.
开始讲述Credit不为人知的故事并深入思考其成功背后的东西.
2. 道可道也非恒道也
^^^^^^^^^^^^^^^^^^^
公司2007年通过CMMI L3认证,本人参与了一个评审项目的全过程,包括准备访谈.
Credit借鉴CMMI的一些地方,比如"需求跟踪矩阵",并进行了很大的定制和剪裁.
Agile的核心,是在条件不成熟时,如何有效地利用现有资源,把事情做好.
这一点在Credit有非常好的体现.结对,自组织,迭代等各领域的优秀模式在Credit
都得到了很好的应用和实践.正因为足够敏捷,Livedoor的膨胀模式能得以保证.
Credit不同于外包项目,除了日方提供原始业务需求外,整个项目生命周期内的
所有环境都在Credit进行:分析,设计,开发,测试,部署,维护等等.
道可道非常道.Credit从根本上讲是Agile,但不是流行的任何一种,或者说任何
一种在Credit的应用背景下,都会失效.
如果你在开发中遇到以下问题之一,那么你就可以参考Credit了.
* 服务质量要企业级的,零缺陷.
* 需求随时会变化,也许刚刚完成代码,立即被告知业务需求变了.
* 业务对应十万火急,一天能上线数十个功能点.
* 经常加班才能完成工作,甚至越干活越多.
* 需求文档,业务代码和实际业务,三者不一致.
* 代码量巨大,业务复杂.
3. 团队结构与角色数
^^^^^^^^^^^^^^^^^^^
要做到高效率,高质量,必须砍掉团队中影响效率或冗余的环境.
Credit的团队,只有2层,这样大大减少了纵向的交流成本和失误.
....................................................
| +----测试
| | |
日方担当 ---|--- 翻译 | <=== 领导(经理/组长)
| | |
| +----开发(设计)
(需求) | (项目组)
....................................................
以上示意图是Credit的层次结构
第一层(需求), 由日方担当组成,提供原始需求,或者需求文档.
第二层(项目组),由开发,测试,翻译组成,翻译是中日方交流的桥梁.
需求,就是提出原始需求,提出方式包括口头,Email,IM,Doc等
项目组,三个角色平行,构成环状,由项目领导统一管理.
从职能上讲,Credit共有5种角色.
日方担当::各公司叫法不一,职责是准确理解并表达业务和反馈,存在于第一层.
翻译::准确理解,正确充分表达日方担当和项目组的意图.
领导::负责全部项目或子系统的整个生命周期,一般是经理/组长/资深开发人员.
开发::负责项目的设计,开发,实施等生命周期.
测试::与开发人员一同理解需求,编写测试用例和测试文档.
其中项目领导也是开发人员,并负责核心内容.
典型的运作模式是以下步骤运作的.
1. 日方担当理解业务需求,并通过CVS/Ticket/Skype/Email等方式整理出一个需求.
2. 翻译主动或被动得知上步的需求,并及时准确的翻译(通常速度是每分钟100-200文字)
3. 开发与测试得知步骤1时间,或翻译或互相通知,评审需求.
4. 如果需求有致命问题,则通过翻译及时反馈给日方担当,视紧急程度(skype,email等)
5. 如果问题不影响开发进行,则测试着手测试用例和继续评估影响.开发着手编写代码.
6. 如果编码时发现需求问题,及时通过翻译与日方担当确认,暂停或进行其他开发任务.
7. 如果需求没问题并且开发结束,测试人员直接测试功能代码,及时反馈问题或bug给开发.
8. 如果上述过程出现复杂问题,需要由项目领导协助解决.
长期的磨合和实践证明,以上模式十分高效,可以在编码前扫除绝大部分障碍.
并且项目相关人员的业务理解相当准确和全面,大大降低bug率.
角色最佳搭配比例是(现在的角色比例):
日方担当(2.5):翻译(1):开发(4):测试(1)
需要说明的是,开发指有效开发人员,即实际对应能力,而不是人头数,如果结对,
那么2个人头算1个开发,如果开发人员同时担负系统维护或DBA工作,那么按担负比例计算.
现在的很多对外企业中不存在翻译这面一个实体,这点非常低效,而且成本偏高.
试思考以下问题,结果十分明了.
* 1个专业翻译加4个高级开发人员
* 5个高级开发人员,外语达到专业水平
* 分别提高专项技能和同时提高2项技能
3. 工欲善其事必先利其器
^^^^^^^^^^^^^^^^^^^^^^^
软件工程,是思维创造项目,人是第一要素,人的选择直接关系到项目成败.
"赢在中国"中,史玉柱有个结论:"工资越高则公司成本越低".
Credit验证了这一结论的正确性.为什么这样说呢?
* 高级人才才可以得到高薪.
* 高级人才不需要过多管理成本.
* 高级人才创造力和解决问题的能力,回避风险都很高.
* 高薪意味着稳定,不易被挖走.
选人涉及到的一个硬性问题就是公司预算.
在预算范围内,要尽量招入高级人才,也要搭配普通人才,可以参考以下比例,
* 预算按人头计算,则要至少保证高级人才和普通人才1:4的比例.
* 预算总额度计算,则尽量少招普通人,高级比普通的最多比例是1:1.
什么是高级人才呢?
在Credit有3个指标,按优先级顺序分别是:品质,态度,能力.
品质,是个总和的主观范畴,包括道德,办事能力,团队协作,学习能力等等
态度,主要是工作态度,要求积极主动,敢做敢当,知错即改等
能力,主要是技术能力,包括基础知识,技术视野.
能力可以后天培养,态度决定结果,品质伴随终生.
"好人不用管,赖人管不住",好的人才,管理成本和风险都要小很多.
3. 人之初性本善
^^^^^^^^^^^^^^^
现代教育西化,处处唯我,忽略很多中国本土的东方智慧.
"人之初性本善",在开发团队中,绝对适用,实用,好用.
面对如此这般"善"人,谁会忍心做以下事情呢?
* 大搞政治,办公室政治害人害团队,使人离心离德,处处提防.
* 官僚主义.老百姓心中有杆秤,以德以能服人,胜过所有假权威.
* 故作2B状(装B,傻B).诸多团队的失败原因可以参考本条.
好的团体不需要管理,只需要呵护和引导.
但如何才能建立好的团队呢? Credit具有以下基本特征.
* 积极和谐的气氛,平等,自由,活跃,互助.
* 主动分担任务,不推卸责任.存在是为了对其他人负责.
* 双赢思维,换位思考,未雨绸缪,运筹帷幄.
4. 千里之行始于足下
^^^^^^^^^^^^^^^^^^^
团队组建完毕,正式立项,并着手实际的工作.
.....................
视乎没人感兴趣哈,费劲把力的 ...
分享到:
相关推荐
作为软件技术专业的核心课程,这门课涉及到软件开发的实践操作,因此需要大量的案例、实战项目和模拟工具来支持教学。新媒体环境下的资源库可以整合各种形式的Android开发教程、代码示例、在线编程环境等,使学生...
这门课程是为那些对软件开发有深入理解并希望提升专业技能的学生设计的。在清华大学的学习资源中,这份"软件工程"的资料集合无疑是宝贵的财富。 首先,我们要理解软件工程的核心概念。软件工程是一门应用工程原理、...
再者,学校重视教材和教学资源的建设,编写并出版了多门专业教材,并开发了核心课程的数字化资源,如仿真软件等,提升教学质量。这些教材和教学资源的建设,为学生的学习提供了丰富的资源,使学生能够更好地理解和...
学生需要学会如何编写代码注释、设计文档、用户手册和项目报告等,这对于他们未来在软件开发领域的发展至关重要。 总而言之,基于课程群的C语言综合改革实践与探索,是一个集多方面、多层次、系统化于一体的教改...
在计算机编程语言的大家族中,VB(Visual Basic)作为一种经典且亲和力强的语言,一直以简单易学而著称,它不仅为编程初学者铺平了一条学习的捷径,而且在软件开发领域中扮演着重要的角色。VB的历史沿革和技术特色,...
每次更新都体现了软件开发团队对提升用户体验的不懈追求与努力。 总而言之,术语云v2.1.4不仅为翻译专业人士提供了强有力的辅助工具,也为翻译爱好者开启了高效学习的大门。在这个知识共享、协作互动的平台上,用户...
正是这些特点,使B/S模式在用户群体中受到了广泛的欢迎,并促使更多开发者转向基于Web的应用开发。 **1.1.2 JavaScript的应用场景** 尽管JavaScript最初是为浏览器环境设计的,但随着时间的推移,它的应用场景已经...
这门课程旨在培养学生的Android软件开发技能,但传统的教学模式往往存在一些问题,如内容枯燥、学生参与度低、实践能力不足等。为解决这些问题,引入案例教学法是一种有效的策略。 案例教学法强调以学生为中心,...
乐乐英语--农艺园作为一款早期教育启蒙软件,融合了科技与教育,特别针对儿童的成长需求,创造了一个充满活力与趣味的学习环境。这款软件旨在通过结合英语学习与农业知识的教育模式,让孩子们在欢乐的氛围中自然地...
至于“内测”这个概念,它指的是软件开发过程中的一个早期测试阶段。在这一阶段,软件尚未完全开发完成,许多功能仍在完善之中,可能会存在一些问题和不足。开发者会邀请一部分用户参与测试,他们的反馈对于发现和...
C语言是一种广泛应用于软件开发领域的高级编程语言,因其功能强大、表达能力强、灵活性高和高效性而受到全球程序员的青睐。C语言程序设计课程是计算机科学与信息管理专业的核心基础课程,对于培养程序员的专业技能至...
项目教学法通过让学生参与真实的计算机项目,例如网页设计、软件开发等,使学生在动手实践中加深对理论知识的理解,并提高解决实际问题的能力。学生以小组合作的方式完成项目,这不仅能提升学生的团队合作精神,也有...
例如,擅长音乐的人可能会在音乐软件开发中发现独特的用户体验设计,而擅长绘画的人或许能在界面设计中找到自己的一席之地。 课程中的绘画环节还体现了团队协作的重要性。在选择谁来画黑板画时,组长的角色变得尤为...
此外,5G消息的落地实施还需要跨行业的合作,包括电信运营商、设备制造商、软件开发商、内容提供商等。这种生态系统的构建将促进技术创新和产业链协同,进一步推动5G相关产业的发展。同时,5G消息的安全性也需要得到...
此外,他还掌握了面向对象程序设计和常用的设计模式,这使得他在实际开发中能够灵活运用,提高代码质量和效率。 总体来看,陶涛涛作为一位PHP应届毕业生,不仅具备扎实的理论基础和实践经验,还在项目管理和团队...
2019年,为了更好地理解这一庞大开发者群体的需求、挑战以及对未来的展望,Python基金会联手知名软件开发工具提供商JetBrains,共同发起了一项全球性的Python开发者调查。这项调查覆盖了150个国家和地区,收集了超过...
开源软件的兴起,打破了传统商业软件的封闭性,为行业带来了新的竞争与合作模式。开源运动的核心价值在于其透明性和开放性,促进了市场竞争、技术交流和创新。在原本由单一厂商主导的市场中,开源软件的介入如同打开...
其次,嵌入式系统的研究和开发是当前电路与系统学科的热点之一。Linux系统、嵌入式技术与应用软件的开发对于物联网、智能家居、移动通信设备等领域至关重要。这些技术在自动化设备、工业控制、医疗设备等方面发挥着...
### Linux设备驱动:机制与策略的精妙平衡 在探讨Linux设备驱动的奥秘之前,让我们先明确一点:驱动程序是...随着硬件的不断革新,Linux设备驱动的开发永远是一个充满活力的领域,等待着更多有志之士的探索与创新。