格物学 计算机软件工程

名不副实的“软件工程”

格物自测!为高考,从高一就准备自己的知识点储备!
名不副实的“软件工程”

  文/余晟

  按:本文的很多观点来自与七牛云存储首席架构师道哥(李道兵)的讨论,在这里对道哥表示感谢。

  高校的计算机教育与时代脱节,这已经成为大家的共识。如果要问哪些课程脱节最严重,我的答案是软件工程。其他的课程虽然也有脱节,但多少有点用处:编程语言虽然不教怎么把程序写漂亮,至少教了语法;网络课程虽然没有形象直观的展示,毕竟通讯协议还在使用;数据库课程不讲数据库的安装和调优,关系代数理论仍然是不少问题的原型;数据结构与算法即便看起来与开发没有直接关联,有了概念总不会吃亏

  只有软件工程,是例外。顾名思义,软件工程讲的应当是把软件开发出来的学问。所以,它是名不副实的:如果你按照软件工程教的去做,多半开发不出来软件,至少开发不出好的软件。一方面大量毕业生不会写程序、写不出好程序,另一方面合格的软件工程师奇缺,对这种怪异的景象,名不副实的软件工程功不可没。

  不信?我在写作本文之前专门查阅了如今流行的软件工程教材,共同的大纲如下:

可行性研究

形式化说明

软件研发模型

设计-实现-测试

面向对象分析、方法、实现

 

项目管理

  如今真正做过软件开发的人觉得这些名词和自己的开发有多大的关系?就我的调查,大多数人的答案是没多大关系。但是大多数人的日常工作,分明又是软件工程。那么,此软件工程和彼软件工程为何不一样,问题到底出在哪里呢?按照我的总结,主要有以下几个方面。

  教材上的软件工程是理论先行的,现实的软件工程是实践先行的。

  理论先行的潜意识,就是把现实世界削删之后装到理想的世界里,受到预定义的规范和定理的支配。早期的软件开发确实可以严格遵循这种套路,比如银行的业务就与关系数据库理论严密契合,所以要做的是直接映射到复杂(完美)的实体-关系中,用数据库表加以实现。所以,重要的问题是分析,也就是找到对应的理论模型,然后进行设计和开发。

  现代软件开发的环境则有很大不同。软件需要解决的不再是经典问题,而是复杂的现实问题,这类问题背后根本没有统一的抽象模型。比如当前热门的 NoSQL,出现的原因是大家发现很多问题不是关系模型可以解决的。然而不是关系模型的模型到底是什么模型,根本没有理论答案,所有人都在不断摸索和总结,虽然有了一些中间阶段的解决方案,但各个流派至今也没有统一。既然没有理论,就只能在实践中不断思考、摸索、总结,并及时关心了解业界的最新经验。很不幸,这样的工作方式并不包含在软件工程的教材里。

  实践先行的另一个表现是,必须意识到软件运行的环境是不可靠的用户是不会按照说明书的严格规定来使用软件的,安装软件的操作系统可能缺乏某个类库,软件运行的硬件环境往往并不可靠 我们说一款软件(或者一套系统)工程做得好,往往就是肯定它们已经预先考虑到了各种异常情况,并且都准备了适当的应对预案。能够在开发之前思考各种异常并设计应对方案(为失败而设计),这是软件工程师的基本素质。不幸的是,软件工程教材也没有教授这样的素质。

  教材上的软件工程是单机环境的,现实的软件工程是网络环境的。

  如果你仔细留意就会发现,在软件工程的教材里,计算机的资源常常被假设为无限的,它们给了开发者披坚执锐的勇气。即便有工程相关的考虑,往往也只是针对这个流程的思考而已。比如常见的图书管理系统,几十万几百万图书的信息虽然人工管理起来无比麻烦,计算机却异常简单,根本不用考虑内存、数据库、硬盘、处理速度的限制,所以这些因素大可在抽象思考的过程中忽略。自然而然的,软件工程只需要关心项目管理即可。

  但是有过现实开发经验的人都知道,如今单机的处理能力已经远远不能应对计算机要解决的问题。比如网站的登录服务,从模型上说与图书管理系统差不了多少,甚至更简单。但是用户量的飞涨可能迅速超过了单表、单库能承受的极限,大量用户的集中登录会大量消耗带宽和计算资源,登录信息的保存很可能超过单台机器的内存容量,这还不包括避免会话保持服务器发生异常影响用户体验而必须准备的会话迁移

  在移动互联网推动导致数据和计算量爆炸式增长的今天,几乎所有的程序员都必须从一开始就摆脱单机的思维,掌握这种从逻辑服务、抽象资源及其限制的角度出发看待和解决问题的思考和工作方法。不幸的是,这样的思维方式,教材上的软件工程也没有涉及。结果就是大量系统只能满足于小打小闹,业务稍微增长就无力应对了。

  教材上的软件工程侧重的是开发,实际的软件工程兼顾开发与维护。

  如果你仔细观察就会发现,教材上的软件工程无论怎么强调反馈和改进,总是把大部分篇幅放在了开发上。只要软件的分析准确、设计得当、开发规范,交付之后就解决了大部分的问题。至于软件运行中会遇到什么问题,那是运维的事情。软件的缺陷如何管理,那是下次升级要解决的问题。总而言之,软件交付之后,事情基本就告一段落了。

  但是实际的软件开发中,交付的更准确的说法只是第一次交付,后续还有若干次交付。尤其在时间紧急的项目中,根本不可能有那么多时间去分析和设计,只能保证几个主要的功能运行正常。之后再投入精力去改进和完善这个半成品。对优秀的软件工程师来说,这种权衡能力是非常重要的。不幸的是很多人都不具备这种能力,结果要么是过度设计导致迟迟不能交付,要么是毫无设计和规划导致改进和完善困难重重。可惜,这种权衡的能力,教材上的软件工程并没有涉及。

  现代软件开发的另一个特点是,开发的结果不再是一次定型的软件,而是需要不断维护和改造的系统。系统既要根据实际的运行环境不断调优,又要持续根据用户(而不是一锤子买卖的客户)的反馈迅速改进甚至是调转方向。所以优秀的软件工程师一方面会关心系统的运行状况,不会一股脑扔给运维人员去解决,另一方面还得设计出柔韧而健壮的系统架构,并且有勇气和耐心持续投入精力去维护和改造,有时候甚至要毫不犹豫地推倒重来。很可惜,这种持续打磨的工作模式,教材上的软件工程也没有涉及。

内容来自网友回答


文山学院软件工程怎么样?

只能说一般,我虽然是这个学校的学生,可是事实就这样,整体师资水平较低 不过话有说回来,真要到了大学,学的怎么样,还是要靠自己,如果你真的足够认真,我保证,在这里你也绝对会学的很好,里面有很多关于学习和生活各方面的优惠政策,都是利于学生,我是深有同感,政策真的很好,学校也真的是想为学生的学习提供一个很好的环境,各方面都已经很完善了,而且校区的景色非常美,来到这里,学习之余,赏赏风景,也是一件很美的

吉林农业科技学院软件工程怎么样?

吉林农业科技学院软件工程怎么样?

只能说一般,我虽然是这个学校的学生,可是事实就这样,整体师资水平较低 不过话有说回来,真要到了大学,学的怎么样,还是要靠自己,如果你真的足够认真,我保证,在这里你也绝对会学的很好,里面有很多关于学习和生活各方面的优惠政策,都是利于学生,我是深有同感,政策真的很好,学校也真的是想为学生的学习提供一个很好的环境,各方面都已经很完善了,而且校区的景色非常美,来到这里,学习之余,赏赏风景,也是一件很美的

有没有CCAT 软件工程师认证 什么是CCAT?

有没有CCAT 软件工程师认证 什么是CCAT?

CCAT是Certificate of Comuter Alication Techniques的简称,中文全称是“全国信息化计算机应用技术资格认证”,是由国家人事部中国高级公务员培训中心和教育部全国高等学校计算机教育研究会共同推出的一种在IT业,重操作技能、重管理能力的一种专业技术认证培训和认证考试。 CCAT资格认证项目宗旨就是要建立一套全新的计算机应用技术人才培

看看一个软件工程师平均一天写多少编写功能点

看看一个软件工程师平均一天写多少编写功能点

是说产品设计师还是开发工程师呢?产品设计师的工作量不是这样进行计算的吧?想要问一天写多少个功能点?还是统计开发人员一个功能点需要几天开发完成?但这个也是跟复杂度有关的啊学软件工程专业的,到时候毕业能从事什么工作。感觉好迷茫。 技术只是一块敲门砖,找到的工作也不一定对口,只要你的技术学到家了还怕以后迷茫吗?单片机

河南牧业经济学院软件工程怎么样?

河南牧业经济学院软件工程怎么样?

只能说一般,我虽然是这个学校的学生,可是事实就这样,整体师资水平较低 不过话有说回来,真要到了大学,学的怎么样,还是要靠自己,如果你真的足够认真,我保证,在这里你也绝对会学的很好,里面有很多关于学习和生活各方面的优惠政策,都是利于学生,我是深有同感,政策真的很好,学校也真的是想为学生的学习提供一个很好的环境,各方面都已经很完善了,而且校区的景色非常美,来到这里,学习之余,赏赏风景,也是一件很美的

信阳职业技术学院软件工程怎么样?

信阳职业技术学院软件工程怎么样?

只能说一般,我虽然是这个学校的学生,可是事实就这样,整体师资水平较低 不过话有说回来,真要到了大学,学的怎么样,还是要靠自己,如果你真的足够认真,我保证,在这里你也绝对会学的很好,里面有很多关于学习和生活各方面的优惠政策,都是利于学生,我是深有同感,政策真的很好,学校也真的是想为学生的学习提供一个很好的环境,各方面都已经很完善了,而且校区的景色非常美,来到这里,学习之余,赏赏风景,也是一件很美的

兴义民族师范学院软件工程怎么样?

兴义民族师范学院软件工程怎么样?

只能说一般,我虽然是这个学校的学生,可是事实就这样,整体师资水平较低 不过话有说回来,真要到了大学,学的怎么样,还是要靠自己,如果你真的足够认真,我保证,在这里你也绝对会学的很好,里面有很多关于学习和生活各方面的优惠政策,都是利于学生,我是深有同感,政策真的很好,学校也真的是想为学生的学习提供一个很好的环境,各方面都已经很完善了,而且校区的景色非常美,来到这里,学习之余,赏赏风景,也是一件很美的

软件工程中的DFD图和UML建模有什么区别,重点举例说明用面向对象的方法在软件工程

软件工程中的DFD图和UML建模有什么区别,重点举例说明用面向对象的方法在软件工程

UML是面向对象的分析设计方法,DFD是面向数据流的设计方法。当然UML功能强,表述容易清晰,对将来采用面向对象的实现会省很多力气。 UML是面向对象分析方法的表达工具,涉及的图包括用例图,活动图,类图,时序图,协作图,状态图等等;可以涵盖从需求分析到设计,编码整个开发过程用到的模型。 DFD是面向过程分析方法的表达工具,功能大概等价于用例图,活动图,加上E-R模型,可以涵盖

高考倒计时 2025-02-192025年高考时间 6月7日,8日,9日
软件工程专业其他问题:
高中知识点
相近专业 计算机科学与技术 软件工程 网络工程 物联网工程 数字媒体技术 智能科学与技术 空间信息与数字技术 电子与计算机工程 信息安全