2.Part1 第一章 软件工程的定义与实践

第一章 主要探讨了软件工程与编程之间的区别,并强调了时间、规模和权衡在软件工程中的重要性。

核心内容综述

1.软件工程与编程的区别

在Google内部,软件工程被定义为"随着时间推移的编程"。编程是生成新软件的方式,而软件工程则包括开发、修改和维护代码。编程更多关注代码的生成,而软件工程则需要考虑代码的生命周期、维护性和可持续性。

2. 时间对软件工程的影响

代码的预期寿命(从几分钟到数十年)对软件工程的复杂性有显著影响。短期代码通常不需要考虑底层库、操作系统、硬件或语言版本的变化,而长期代码则需要适应这些变化。

时间的增加使得软件工程需要应对更多的变化和维护问题。

3.规模与效率

软件工程的复杂性与组织规模和项目规模密切相关。随着组织的增长和项目的扩展,开发工作流程的效率可能会受到影响。

规模问题不仅涉及技术层面,还涉及团队组织、沟通和管理策略。例如,《人月神话》中讨论的沟通和人员规模问题,仍然是软件工程中的重要议题。

4.权衡与决策

软件工程中经常需要在多个路径之间进行权衡,这些决策通常涉及高风险和不完善的价值指标。

软件工程师的目标是实现组织、产品和开发工作流程的可持续性,并管理扩展成本。

Google的经验与本章的目标

本书分享了Google在构建和维护预计将持续数十年、涉及数万工程师和全球计算资源的软件方面的经验。

这些经验虽然针对大规模项目,但也适用于较小规模的开发工作。

本章要点

**时间维度:**软件工程不仅仅是编程,还需要考虑代码的生命周期和长期维护。

**规模问题:**组织和项目的规模对软件工程的复杂性和可持续性有重要影响。

**权衡决策:**软件工程师需要在多个选项中做出权衡,以实现可持续性和扩展性。

Google的经验:本书的目标是分享Google在大规模软件开发中的经验,帮助读者在自己的项目中应用这些最佳实践。通过这些内容,第一章为读者奠定了理解软件工程的基础,并引入了时间、规模和权衡这三个核心主题

精彩语录

1.编程和软件工程之间有三个关键的区别:时间、规模和权衡取舍。在一个软件工程项目中,工程师需要更多关注时间成本和需求变更。在软件工程中,我们需要更加关注规模和效率,无论是对我们生产的软件,还是对生产软件的组织。

2.编程当然是软件工程的一个重要部分:毕竟,编程首先是生成新软件的方式。如果你接受这一区别,那么很明显,我们可能需要在编程任务(开发)和软件工程任务(开发、修改、维护)之间进行划分。时间的增加为编程增加了一个重要的新维度。这是一个立方体三维模型不是正方形的二维模型,距离不是速度。软件工程不是编程。
Software engineering isn't programming.

3.短期编程与生成预期生命周期更长的代码有何不同?随着时间的推移,我们需要更多地意识到"正常工作"和"可维护"之间的区别。识别这些问题没有完美的解决方案。这是不幸的,因为保持软件的长期可维护性是一场持久战。

4.海勒姆定律:当一个 API 有足够的用户的时候,在约定中你承诺的什么都无所谓,所有在你系统里面被观察到的行为都会被一些用户直接依赖。

5.当专业知识与规模经济相结合时,回报尤其丰厚。

相关推荐
嘿黑嘿呦6 天前
chap 8排序
算法·蓝桥杯·排序算法·软件工程
旧曲重听16 天前
2026前端技术从「夯」到「拉」
前端·程序人生·职场和发展·软件工程
承渊政道6 天前
飞算JavaAI 智能引导背后的多 Agent 协作机制解析:从老旧 Java 后台升级到可运行工程
java·开发语言·spring boot·安全·intellij-idea·软件工程·ai编程
apcipot_rain6 天前
计科八股20260616(1)——堆存中位数、链表判环、黑白测试、敏捷开发与瀑布模型、配置管理、持续集成、池化
数据结构·算法·软件工程
lisw057 天前
【计算机科学技术】路由器(route):概念、历史、内容与战略!
机器学习·智能路由器·软件工程
培培说证7 天前
大数据、人工智能、计算机、软件工程,到底怎么选?
大数据·人工智能·软件工程
文艺倾年8 天前
【强化学习】MDP、贝尔曼方程与CartPole 编程,20W字总结(二)
人工智能·软件工程·强化学习
郝学胜-神的一滴8 天前
CMake 017:彩色日志输出实战
linux·c语言·开发语言·c++·软件工程·软件构建·cmake
小程故事多_808 天前
AI软件工程范式革命,终结五十年的“手工伪工程”时代
人工智能·软件工程
精益数智小屋9 天前
项目管理看板如何拆解任务进度?项目管理看板解决跨部门协作难题
大数据·人工智能·数据分析·云计算·软件工程