昨天,我朋友的孩子报考了软件工程专业,问我软件工程到底学啥?所以我给他开列了一个书单。
现在高校开了一堆花名头的专业:
偏技术类:云计算、大数据、人工智能、物联网
偏应用类:电子商务、信息管理
但我个人感觉,会编程语言、会使用开源框架的人一堆,但是中国太缺系统分析、系统设计、系统架构的人才了,而且这些课程我个人认为应该是软件工程的核心课程,但是好像我国高校的软件工程专业也不教这些东西。
(1)
软件工程也是工程。
一想到工程,我们就想到:
规划、勘察、设计、试验验证、评审
标准规范、注册认证
建造、预构件、大型施工工具
质量监理质量保证、生产安全监管
项目进度管理/成本管理/变更管理、工程文档管理
(2)系统分析
需求分析、系统分析这块我一直没学过什么好书,我自己上大学时考系统分析员也没考通过。
我在需求分析这方面看过的书,只有:《用户故事》。
我在系统分析这方面看过的书,我推荐:《分析模式:可复用对象模型》。其实这本书命名为《分析模式》可能会更好,不用带副标题。
如果说分析的方法论,我感觉推荐一本:《金字塔原理》。
(3)系统设计
系统设计,我特别注重层与层、块与块的关系。这个关系如何既解耦又关联,这是需要技巧的。所以我推荐两本书:《领域驱动设计:软件核心复杂性应对之道》、《设计模式》。
设计标准符号:《UML精粹》。还有一本国人写的《大象:Thinking in UML》也非常好。
(4)架构设计
关于架构,这两本挺好:《企业应用架构模式》《架构整洁之道》
软件架构风格,这些年从组件到SOA服务到微服务,所以我推荐:
面向对象时代:我没看见过好书。另外,大师Booch的《面向对象分析与设计》,我个人感觉,不是一本关于使用面向对象方法进行架构设计方面的好书。
组件时代:《COM本质论》《J2EE Development without EJB》
SOA时代:《SOA核心技术及应用》
微服务时代:《服务架构设计模式》
(5)软件开发
关于编程语言、编程框架的书汗牛充栋,但是站在软件工程角度看软件开发实现的书就很少了。
我推荐几本:
《测试驱动开发》
《重构》
《代码整洁之道》
《极限编程》
(6)质量保证
本来软件测试、质量保证,这是软件工程非常重要的组成部分。可惜,我一本好书也没见过。可见大家对软件质量的事实的不重视。
(7)工具
说起软件开发的各种工具,大家对开发IDE、框架、前端UI组件、运行中间件、数据库如数家珍。站在软件工程的角度,大家对各种CI持续集成、CD持续发布、DevOps工具也不太陌生。
也许是我孤陋寡闻,我个人在这方面看过的唯一一本感觉好的书就是:《持续交付:发布可靠软件的系统方法》。
(8)过程管理
软件工程管理,如果大家想从整体框架概要上学习,我首推《TOGAF标准手册》。不知道啥原因,好多人把TOGAF当做软件架构方法来看,我个人感觉不妥。如果大家真要做软件架构,建议还是看看我上述在系统架构设计一节中推荐的书,那些知识才能让你的软件真正具有架构性。你看完TOGAF你也不会让你的软件具有架构性。很多企业IT决策人特别喜欢引入TOGAF,以为TOGAF学习了使用了就能让软件有架构性,这真...。
综合类的我推荐《代码大全》,实践类的我推荐《微软的秘密》。
论项目管理图书,我推荐《PMBOK指南》。我是强烈推荐在软件研发过程中引入专职的项目经理的,不要让产品经理、开发部门经理或开发Leader担任项目管理的职责,这是大大的误区。
《人月神话》是软件工程类非常知名的书,不过我不推荐阅读。
大家一想到软件工程就想到项目周期非常长、参与人数非常多、项目流程非常重。我个人在软件研发领域从业这么多年,给我一个感受就是:各专业部门各目标不一致、共享信息传递信息效率慢/信息失真变形。所以我一直推崇小团队、精益小团队、全职能团队、外科手术医生式团队。我推荐给大家一本书:《SCRUM敏捷软件开发》。
另外我个人不太喜欢敏捷Agile这个表达,我感觉这个词让大家产生了误解,我更喜欢用精益Lean这个词,就是现在经常讲到的市场-产品匹配、需求-实现匹配。这几年随着华为国产化崛起,大家一窝蜂学华为,所以IPD这个很古老的词汇和方法又在中国IT业界流行了。大家一想到IPD来自IBM就觉得这个方法很笨重。不过我倒推荐两本书:《IPD华为研发之道》《IPD重构产品研发》。这两本书都是离职的华为人写的,但是实际上写的也不是IPD更不是IBM的那套IPD,只不过打的是IPD的名头,不过内容蛮鲜活的,市场-产品匹配、需求-实现匹配、市场-需求-产品-实现各部门各岗位如何串联。