需求变化与IoC
【感谢 Todd投递本文 – 微博帐号:@weidagang 】
需求又变了,怎么办?
先上一个轻松的段子:
程序员XX遭遇车祸成植物人,医生说活下来的希望只有万分之一,唤醒更为渺茫。可他的Lead和亲人没有放弃,他们根据XX工作如命的作风,每天都在他身边念:“XX,需求又改了,该干活了,你快来呀!”,奇迹终于发生了,XX醒来了,第一句话:“需求又改了?”。
这个段子用幽默的方式反映了需求变化是每一个程序员、架构师或项目经理都会经常遇到的问题。面对这个问题,不同的人有不同的应对之道,最近微博上有一段关于需求变化的讨论:
@假装刺猬的猪:我们在软件开发过程中,会持续碰到客户需求变更的情况。如果没有领域建模,我们单纯将问题使用直觉将问题解决,那么等到客户需求变更或者有新的需求时,就会面临一个僵硬的前设计!无法在以前的设计上持续深入的优化模型,导致需求变更无法及时深化。设计实现均滞后与变更!
@高煥堂: <碰到客户需求变更的情况>是合理的;但<领域建模>不是美好的手段!!!
@weidagang: 要不被客户牵着鼻子走,需要自己有很强的设计能力,反过来让客户跟着你的设计来满足你的要求。能做到这点的公司很少,但这是软件行业唯一有希望的出路。
@高煥堂: <这是软件行业唯一有希望的出路>。 Great!!
如何应对需求变化? @假装刺猬的猪 的答案是领域建模,并持续优化模型,适应需求的变化。@高煥堂 则认为领域建模不是美好的手段。我进一步补充,应该“反过来”让自己在需求变化中处于主导地位,而不是被动地适应。
控制反转 (IoC)
什么样就算是“反过来”了呢?举个例子:
用户想购买一台普通PC,他只想电脑能流畅运行魔兽世界,他根本不想知道什么叫主板,什么叫内存,什么叫CPU;但他不得不接受必须购买主板、CPU、内存的事实,因为PC架构是产业标准,而不是由用户定的。客户有选择的权利,但没有设计的权利,客户的需求必须在设计框架下得到满足。
这里我们要问PC架构是保护了谁的利益?显然,直接的受益者是厂商。如果没有PC架构的保护,厂商就会直接面对客户,客户说我需要功能A,我马上分析设计实现功能A;客户说我要功能B,我马上分析设计实现功能B … 有了PC架构的保护,厂商就变得更加强势,用户的一切需求都必须在PC架构下来谈。厂商可以倾听用户的声音,不断改进产品,但设计主导权永远在自己手中。我们IT行业常常用“做产品”和“做项目”的视角来区分不同的公司,但很少有人用“做设计”的视角来看。实际上,关键的问题在于设计主导权是厂商还是在客户。如果设计主导权在客户,不管是做产品、做服务还是做项目,其命运必然是疲于奔命应付客户,最后获得微薄的利润;如果设计主导权在厂商,不管做产品、做服务还是做项目都能有更多的话语权和更高的利润。
当然,光有设计还不够,必须客户接受才能起到通过设计掌握主导权的作用。这一方面需要自己具有很强的设计能力,如苹果就是以设计能力著称的公司;另一方面,和其他厂商结盟壮大阵营也是一种方法,如最著名的Wintel联盟(Windows+Intel),以及现在的日益壮大的Android阵营都属于此类。假如有厂商不遵守PC产业标准,说我的PC就没有主板,没有显卡,因为用户更不不需要这些东西;那么,它要么像苹果一样独树一帜成为一种新的标准,要么无人问津。
我所谈到的“反过来”本质上就是软件设计中的控制反转 (Inversion of Control, IoC)思想。IoC是每一个初级程序员向高级进阶所需要了解的最重要的设计思想。由于Spring等开发框架的流行,知道IoC概念的程序员不在少数,但不少人对于IoC的理解仅仅停留在通过依赖注入 (Dependency Injection)实现解耦这个层面。实际上,IoC的应用不仅包括解耦,它还是框架的基本原理,在非计算机领域,IoC也是无处不在,如果你能从上面的例子中体会到IoC,这才算是融会贯通了。
软件开发中一种最常见的模式是“以用户为出发点,以需求分析为核心”。该模式提倡从用户需求中分析推导出设计和实现,比如,TDD式的设计正是这类典型。而IoC式的软件设计与此截然相反,IoC的设计是一种“以愿景(自身利益是愿景的重要方面)为出发点,以架构为核心”的模式。如果用户的需求是一台电脑,我们如何能通过第一种模式分析需求推导出“主板-CPU-内存-外设”的PC架构呢?恐怕很难。IoC式的设计是以用户看不见摸不着的架构为核心,自己主导设计,用户需求是设计的约束条件和验证手段,而不是出发点和目标。我们想要掌握主动,不被需求变化搞得疲于奔命,就必须熟练使用第二种模式。
我们的人生都被环境和各种客观条件所束缚,多数人只能随波逐流,听从命运的安排。你有没有想过要拥有人生的主导权呢?既然你是程序员,你懂IoC,你能否设计自己的人生框架呢?Yes,you can!
(转载本站文章请注明作者和出处 酷壳 – CoolShell.cn ,请勿用于任何商业用途)
相关推荐
陈皓在其撰写的文章《征文_陈皓:年度安全规划–“我们不一样”》中,详细论述了基于当前技术趋势的安全规划策略,包含了渗透测试、自动化、安全防护、物联网安全以及业务安全等多个维度。 渗透测试是指在安全专家...
在信息安全领域,有这样一位专家,他的自信源于对专业知识的深厚积淀与丰富的实践经验。他就是陈皓,一位在安全开发、安全架构以及数据安全等领域有着卓越贡献的人物。陈皓的故事,是一个从兴趣出发,到专业深造,再...
《跟我一起写 Makefile》由陈皓撰写,祝冬华整理,是一份深入讲解Makefile的教程。Makefile是Linux环境中用于自动化构建、编译和链接程序的重要工具,它通过简洁的规则定义来管理复杂的项目构建过程。以下是该文档...
关于铁道部的火车票网络订票系统,这些天招致的骂声不断,当然,除了发泄...(这又是一篇长文,只讨论性能问题,不讨论那些UI、用户体验、或是否把支付和购票下单环节分开的功能性的东西)任何技术都离不开业务需求,
陈皓勇:新时代电力系统科研创新探路者.pdf
这篇文章必然是有争议的,我在我的微博上讨论过很多次了,每次都是很有争议的。有不同的观点,有争论总是一件好事,这样可以引发大家的思考。所以,对于我的这篇博文,如果你赞同我的观点,我会感到高兴,如果你会去...
《编程修养 -- 陈皓》是一本专注于提升程序员在使用C/C++编程语言时的技艺与素质的著作。书中的核心理念是强调编程不仅仅是一种技术,更是一种艺术,需要程序员具备良好的修养,才能编写出高质量、易读性强的代码。...
与`while`循环相比,`for`循环减少了重复代码,提高了代码的可读性和一致性。 ### 请sizeof类型而不是变量 在计算类型大小时,使用`sizeof`操作符作用于类型而非变量。这样可以避免由于变量的生命周期或作用域限制...
在持仓分析方面,陈皓的投资组合中前十大重仓股的行业集中度较高,这与他偏好的TMT板块紧密相关。不过,即便是在高配置的电子行业中,其配置比例也不超过25%,保持了某种程度的分散性。 陈皓的投资风格偏于稳健,...
《陈皓左耳多耗子的LeetCode 2017-08-12解题集》 本文将深入探讨由知名IT博主陈皓(网名“左耳多耗子”)在2017年8月12日更新的LeetCode解题集。LeetCode是一个广受欢迎的在线编程挑战平台,它提供了丰富的算法和...
什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员,makefile还是要懂。...特别在Unix下的软件编译,你就不能...——陈皓
陈皓在《编程修养》中强调了五个关键方面,包括钻研精神、积极态度、沟通能力、谦虚谨慎以及编写高质量代码。其中,编程修养的核心就是写出稳定、易读、规范、易维护且专业的代码。 【编程规范】是提高代码质量和...
《跟我一起写Makefile》是陈皓在2021年04月06日发布的一本关于Makefile技术的PDF教程,旨在帮助读者深入理解和掌握Makefile的编写技巧。Makefile是软件构建自动化工具的核心,它允许程序员自动化编译、链接和其他...
在分布式系统的问题中,传统单体架构与分布式服务化架构在新功能开发、系统性能、系统运维、技术测试、系统扩展性和系统管理等方面都有明显的差异。分布式服务化架构具有开发快速、扩展性好、故障影响小、高并发处理...
- **重载内建隐含规则**:如何覆盖默认的隐含规则,以适应特定的需求。 - **老式风格的"后缀规则"**:介绍了一种传统的规则类型,用于处理文件扩展名。 - **隐含规则搜索算法**:描述了make如何根据文件名找到适用...
本文以陈皓编写的《跟我写makeFile》为例,详细讲解makefile编写的各项知识点。 1. makefile基本概念 makefile文件中定义了一系列的编译规则,告诉make程序如何编译和链接程序。规则由目标(target)、依赖...
编译器需要的是语法的正确,函数与变量的声明的正确。对于后者,通常 是你需要告诉编译器头文件的所在位置(头文件中应该只是声明,而定义应该 放在 C/C++文件中),只要所有的语法正确,编译器就可以编译出中间目标...
《编程修养》是陈皓先生的一本著作,旨在引导程序员提升自身的编程素质,注重代码的可维护性和良好的编程习惯。本书深入浅出地探讨了编程过程中的一些关键要素,旨在帮助开发者编写出更高质量的代码。 首先,编程...
《GDB调试程序[陈皓]》与《GDB调试工具指南》这两份PDF文档,是深入了解和精通GDB(GNU Debugger)这一强大调试工具的重要参考资料。GDB是开源世界中广泛使用的C、C++以及其他多种语言的调试器,它允许开发者在运行...