本文的意图是讨论软件工程的未来发展趋势,但是软件工程的发展不可能是孤立的,所以我们首先需要思考一下计算模型和软件开发本身的变化和趋势,再由此推测软件工程的发展趋势。

从计算模型而言,应该来讲,传统的冯·诺依曼仍然被沿用;但从计算能力上来讲,我们注意到了三个变化:
CPU的运算能力按摩尔定律快速提升;但提升单颗CPU的计算能力已经越来越困难

并行运算技术以及多核多线程技术使服务器的处理能力飞速提升;服务器的处理能力不再是瓶颈,从而造成计算能力大量向服务器端迁移,C/S结构被无情抛弃,薄客户端(B/S结构)成为大势所趋。


互联网的快速普及使得云计算成为可能,通过互联网相连的服务器集群在服务器端提供了更强大的计算能力

基于上述计算能力的变化,从软件开发模式而言,我们注意到以下六个相关的趋势:

由于计算能力向服务器端的快速集中,提供高并行计算能力和可用性的中间件技术被广泛采用,甚至已经成为构建大型软件系统的必选项。

因为采用了中间件技术,软件开发团队可以更集中关注于业务逻辑,而可以将许多细节交给中间件来管理,从而大大减少了需要编写的代码行数,也直接导致了软件开发团队的规模变得越来越小,但角色变得越来越专业化(如了解行业的需求分析员,了解中间件技术和领域构架的架构师等)。

计算能力的增强,使软件越来越易用,从而使软件变得无处不在,需要的软件开发人员数量急剧增长(组织形态是大量的小规模开发团队);在这一因素以及降低成本的压力下,开发外包变得非常普及。

为了使分布在互联网上系统能够互相协作,SOA成为一个热点。

互联网的普及,将原来分散的开发人员聚合在一起,只要有一个合适的基础和好的框架,他们就可以开发出产品级的工具软件(以Eclipse,JBoss,MySQL,Subversion为例),从而开源成为了一种趋势。

B/S结构的系统非常容易升级,这使得软件交付和升级的速度大大加快了(从以年月为单位,到以周天为单位);

回到正题,那么在这些大的趋势的作用下,软件工程会如何发展?

我觉得在未来几年我们会看到如下的趋势:

需求工程,渐成热点:专业化的角色,日益复杂的业务创新,全球分布的团队以及互联网级的交付速度,这些都对需求获取的正确性和有效性提出了更高的要求;我预计需求工程的研究和实施会成为近期的热点,其中Use Case技术会被更广泛而正确的应用,而相关工具的研发也会成为热点(如IBM Rational Requirements Composer、Ravenflow等)。
用例的优势在于它天生是黑盒的,它用自然语言抽象了用户和目标系统的交互,避免了混入分析、设计和实现细节,以保证用例可以被不懂具体技术的业务及测试人员所真正理解。同时,需求分析员又可以方便地通过用例分析(即用分析类来试图在理想方式下实现用例),将需求体系精华成分析模型。在这一过程中,需求分析员可以更进一步地完善基于用例的需求体系,而不必担心分析模型会污染需求,从而实现需求与分析的分离及有效互动。
DSSA和MDD,老树新花(基于领域的构架[DSSA]与模型驱动的开发[MDD]):随着软件应用的日益普及,软件已经超出了将手动流程自动化的范畴,而开始成为业务创新的主要推动力。因此,引入捕获特定领域内最先进需求及其实现架构的DSSA成为行业客户的热点之一。而且,DSSA的引入将MDD门槛大大降低了,也使基于DSSA的MDD支撑工具成为可能,从而可以极大地提高开发效率并保证软件质量(例如,Telelogic的Rhapsody就是一个成功的基于实时嵌入式系统构架的MDD工具)。
迭代/敏捷,渐成标准:随着软件交付周期的日益加快,迭代化开发已经成为大多数软件开发团队的必选项。但是迭代对整个团队的需求、架构、协同及测试能力都提出了更高的要求,现在许多开发团队都在试图导入迭代化开发的过程中,敏捷可以是被看成迭代化开发的一种导入方式,只不过敏捷的范围其实比迭代化开发更大一些。
敏捷的三个要素是迭代开发、坦诚合作和自适应性。坦诚合作其实才是敏捷的精髓,如Ivar所说,敏捷其实是有关Social Engineering的。敏捷的主要贡献在于他更多地思考了如何去激发开发人员的工作热情,这是在软件工程几十年的发展过程中相对被忽略的领域。
持续集成,蓄势待发:持续集成是保证迭代化开发质量的主要方式,通过持续集成可以利用自动化的方式来尽量自动地、尽早保证代码质量。随着迭代和敏捷的流行,持续集成相关的工具成为现在市场上的新热点(如持续集成框架IBM Rational BuildForge, 开源软件CruiseControl,代码静态分析工具Klocwork Insight,IBM Rational Software Analyzer等)。
持续集成是一个复杂的系统工程,组织需要首先将现有的配置管理/变更管理工具与Build环境紧密集成并完成自动化Build过程,在根据企业/项目/产品的现状,定义如何自动化地检测软件质量(代码静态分析、单元测试或冒烟测试),并定义需要自动化生成的管理报表。
基于实践的过程框架,方兴未艾:开发角色的专业化的和分布的全球化都要求软件开发过程更加规范,而敏捷又要求过程必须紧密贴合项目的实际需要,因此传统的大一统的过程无法符合这一需求。新一代的过程将是以实践为核心的,项目可以通过组装所需的不同实践来获得贴近项目要求的过程。IJI(Ivar Jacobson International)的EssWork框架和IBM Rational的RMC都是新一代的基于实践的过程框架。
依据过程专家长时间的经验,他们很小心、很仔细地将一个完整的开发过程组件化,从开发过程抽象出一个个可以被单独导入又可以被组装到一起的实践,从而使逐步求精式的过程改进成为可能。对于一个软件组织而言,如果已经建立一个比较成熟的软件开发流程,但觉得这一流程并不适合所有项目的实际需要,那么目前可以考虑的是用实践的方式去重新梳理现有流程,以使项目组能够以实践为单位来组装出切合项目实际的流程;另外,该组织也可以将适用于本组织的业界流行的实践导入到现有流程当中,IJI公司的专家从业界最佳经验中抽取了八个实践,有关信息可访问http://www.esslab.net:4040/ngp/。
配置管理,昨日黄花:随着开发团队规模的日益减小,配置管理的复杂性大大降低了,我们注意到越来越多的用户转向使用开源的配置管理工具(如Subeverison,JIRA,hosted-projects等等);未来的配置管理工具更多的以一种全生命周期管理平台(Application Lifecycle Management)的方式出现,弱化了单项的配置管理能力而强调了全流程的整合(如Microsoft VisualStudio Team System和IBM Rational Team Concert等)。

即便配置管理的复杂性降低了,但它仍然是开发项目管理的最重要的支撑平台之一。目前的重点应该是加强对项目经理进行有关配置管理知识的培训,让他们理解到配置管理能力(如并行开发、基线回退等等)能够如何帮助项目开发过程的,从而使配置管理工具/环境的价值能够得到充分的发挥。

软件工程队软件开发的重要性我无须赘言了。虽然,我上面列出了一些软件工程的热点,但读者一定要仔细分析组织自身特点,以确定接下来要采取哪些改进步骤,而不应该盲目追求热点!

吴穹博士谈软件工程未来发展趋势相关推荐

  1. 计算机系统未来发展方向论文,浅谈计算机未来发展趋势(期末论文)

    浅谈计算机未来发展趋势 摘要:随着信息技术的发展,计算机在我们的日常生活中扮演了越来越重要的作用,本文所要论述的就是通过现有的技术以及当今在计算机领域还在研究中的尖端科技,对于计算机未来的一些展望以及 ...

  2. 吴穹:金融行业已来到全面推行数字化研发管理的时点

    近日,Agilean 首席咨询顾问.敏捷创新管理专家吴穹博士,在 2020 China DevOpsDays 大咖说活动中,接受了张乐.许峰两位主持人的深度访谈.吴穹博士就敏捷.精益思想和框架,金融行 ...

  3. 软件工程的未来发展趋势[转载]

    此文全文已发表在<程序员>杂志九月号上. 这篇文章的主体是讨论软件工程的未来发展趋势,但是软件工程的发展不可能是孤立的,所以我们首先需要思考一下计算模型和软件开发本身的变化和趋势,再由此推 ...

  4. 浅谈计算机网络的未来发展趋势

    浅谈计算机网络的未来发展趋势 前言 学习主要内容 计算机网络的发展 计算机网络的未来趋势 在线多媒体技术 网络应用更趋多样化 业务综合化 无线传输介质将成主流 计算机的智能革命 学习结论 参考文献 前 ...

  5. 物联网专业真的把人坑惨了?浅谈物联网的未来发展趋势和未来方向

    转载于:https://blog.csdn.net/weixin_43982452/article/details/120200879?spm=1001.2014.3001.5502 大家好,我是无际 ...

  6. 软件工程的未来发展趋势(一)

    此文全文已发表在<程序员>杂志九月号上. 这篇文章的主体是讨论软件工程的未来发展趋势,但是软件工程的发展不可能是孤立的,所以我们首先需要思考一下计算模型和软件开发本身的变化和趋势,再由此推 ...

  7. 浅谈汽车OTA的现状与未来发展趋势

    本文由武翔宇,赵德华,郝铁亮联合创作 摘要 汽车的"属性"正在发生变化,这种改变源于智能的崛起.汽车开始变得不再是一个交通工具,它会不断变化,不断成长.车主会时不时的发现汽车给自己 ...

  8. 物联网专业真的很坑吗?浅谈物联网的未来发展趋势和方向

    大家好,我是无际. 最近几年,我基本都在从事物联网产品的开发,我做的主要是硬件端,也就是单片机开发. 我见证了物联网这几年的发展,也享受了物联网真正给我们带来了便利,我也相信物联网是未来发展的趋势. ...

  9. 实在智能“数字员工”发布,谈AI+RPA发展趋势,发布SaaS平台,并开源可供开发者下载打造小型机器人

    2020年7月15日,人工智能科技公司「实在智能」举办了AI+RPA夏季新品发布会,正式发布新基建的智造者.冲锋队和生力军--"章鱼·数字员工". 创新提出"数字员工&q ...

最新文章

  1. LeetCode--258--各位相加*
  2. Python安装最新版最详细教程(3.10.2)
  3. Android插件化开发之用DexClassLoader加载未安装的APK资源文件来实现app切换背景皮肤
  4. Day-17: 网络编程
  5. 堆以及stl堆的使用
  6. BBIAF的完整形式是什么?
  7. linux里的run-level,linux run level 为何物
  8. deepin中自定义安装的软件如何加入到启动器
  9. IDEA中Maven项目中界面右边的Maven Projects窗口找不到不出来
  10. mysql 5.5 字符集_mysql 5.5字符集问题
  11. java 网络编程 总结篇
  12. Ubuntu系统安装搜狗(sougou for linux)输入法详细教程
  13. 揭密征途赚钱模式:史玉柱在赚谁的钱
  14. layui颜色选择器 拾色器结合表单记录
  15. 大数据时代是什么意思?
  16. 骇客(Hacker)用语
  17. 促活用户新方式:在app内嵌入小游戏
  18. uniapp 小程序实现 RSA 加密
  19. python摄像头人脸识别小程序 开门,OpenCV3-Python人脸识别方法—基于摄像头
  20. 达人评测 r7 7730u和i7 12700h差距 锐龙r77730u和酷睿i712700h对比

热门文章

  1. 科大星云诗社动态20210811
  2. 重磅 | 吴恩达新书《Machine Learning Yearning》1-52 最新章节分享
  3. Coursera吴恩达《神经网络与深度学习》课程笔记(4)-- 浅层神经网络
  4. Spark算子:RDD基本转换操作–coalesce、repartition
  5. 小波的秘密8_图像处理应用:图像降噪
  6. python的set结构
  7. jsp的<a>标签中怎么传递参数
  8. 前端基础——day1
  9. CVS有关no such repository问题
  10. C语言文件操作基本常识