软件工程师进入编程世界的55个锦囊:《 好代码 ,坏代码》

2023-11-04 02:10

本文主要是介绍软件工程师进入编程世界的55个锦囊:《 好代码 ,坏代码》,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

软件工程领域关于如何写出优秀代码的建议和观点非常多。但生活没有那么简单,
绝不只是尽可能多地吸取好的建议并严格遵守。由于不同来源的建议往往相互矛盾,我们怎么知道要听从哪个建议。更重要的是,软件工程并不是一门精确的科学,不可能将其提炼为一套绝对可靠的原则(无论我们如何努力)。每个项目都不一样,几乎总有一些因素需要权衡。

为了写出优良的代码,我们必须对手上的方案有合理的判断,并彻底想清楚特定方法 的结果(好的和坏的)。为此,我们必须了解问题的根本:编写代码到底是为了实现什么目标?实现那些目标需要考虑哪些高层因素?《好代码 ,坏代码》就可以帮助刚入门的软件工程师获取这些技能。

好代码 ,坏代码

[英] 汤姆·朗(Tom Long) 著,姚军,茹蓓 译

Google开发工程师从零讲解高质量代码,整合作者及团队多年的软件开发实践经验,通过50+条锦囊妙计、100+个案例,帮你轻松理解和掌握编程技能。

软件工程师在不断积累经验的过程中会发现,日常编程中所做出的决策对于软件的正常运 行、工作的顺利开展以及其他人的维护有很大的影响。学习编写(从软件工程角度来看)优良代 码需要花费许多年的时间。这些技能的获得过程往往很缓慢。工程师从自己的错误中吸取教训, 或者不断从团队的资深工程师那里得到建议,以特定的方式得到这些技能。

本书特点

本书介绍软件工程师经常用于编写可靠的、易于维护的代码的关键概念与技术。本书并不是 简单列举“该做”和“不该做”的事项,而是旨在解释每种概念和技术背后的核心理论,以及需 要权衡的因素。这应该能够帮助读者对如何像一位经验丰富的软件工程师那样思考和编程有基本 的理解。

本书的读者

本书的目标读者是那些已经具备基本编程技能,想继续提高编程技能的人。本书适合有0~ 3年软件工程师工作经验的人阅读。有丰富工作经验的工程师可能发现,本书中的许多内容他们 都已经掌握,但我希望他们把这本书当作指导其他同行的有用资源。

本书的组织结构

本书分为三部分,共11章。第一部分介绍较为理论性的概念,它们组成了我们对代码的思 考方法。第二部分转向较为实用的经验教训。第二部分的每一章都分为一系列主题,分别涵盖特 定的考虑因素或技术。第三部分介绍创建有效和可维护的单元测试的原则与方法。

本书各章节的总体形式是:先阐述一个可能有问题的场景(以及部分代码),然后说明消除部分或全部问题的替代方法。从这个意义上说,每个章节往往是从展示“坏”代码过渡到“好” 代码,但需要注意的是,坏和好是主观的说法,与语境相关。正如本书所要强调的,在编程工作 中往往要考虑一些微妙的差别和权衡,这也就意味着好坏的区别并不总是一目了然。

第一部分“理论”为一些总体性和较为理论性的考虑因素打下基础。这些考虑因素组成我们像软件工程师那样编写代码的方法。

  • 第1章介绍代码质量的概念,特别是我们打算用高质量代码要实现的一组实际目标。 然后,我们将这些目标展开为“代码质量的六大支柱”,为日常编程使用提供高层策略。
  • 第2章讨论抽象层次。这是指导我们如何构造代码,并将其分解为不同部分的基本考 虑因素。
  • 第3章强调考虑必须使用我们的代码开展工作的其他工程师的重要性。本章还将讨论 代码契约,以及如何仔细考虑这些契约以防止软件缺陷。
  • 第4章讨论软件错误,并阐释为何认真思考错误通知与处理方法是编写优良代码的关 键部分。

第二部分“实践”以更贴合实践的方式,用特定的技术与示例介绍代码质量的前五大支柱(第1章定义的)。

  • 第5章介绍提高代码可读性的方法。这能确保其他工程师理解代码的意义。
  • 第6章介绍避免意外情况的方法。这能确保其他工程师不会误解代码的功能,从而最 大限度地降低出现缺陷的可能性。
  • 第7章介绍使代码不容易被误用的方法。这使得工程师不容易在不经意间编写出逻辑 错误或者违反假设的代码,最大限度地降低出现缺陷的可能性。
  • 第8章介绍实现代码模块化的方法。这种关键技术有助于确保代码表现出清晰的抽象 层次,能够适应不断变化的需求。
  • 第9章介绍代码的重用性和可推广性。这能避免软件工程师重复编写类似代码,使得 添加新功能或构建新特性更加方便、安全。

第三部分“单元测试“介绍编写高效单元测试的关键原则和实用方法。

  • 第10章介绍影响单元测试代码的一些原则和考虑因素。
  • 第11章以第10章介绍的原则为基础,为编写单元测试提供一系列具体、实用的建议。 阅读本书的理想方式是从头到尾完整阅读,因为本书前面的章节是后续章节的基础。尽管如 此,第二部分(以及第11章)中的主题通常相对独立,而且每个主题篇幅较小,因此,即使单 独阅读,也是有益处的。这样的编写方式是有意为之,目的是提供向其他工程师快速解释既定优 秀实践的有效手段。对希望在代码评审中解释特定概念或指导其他工程师的工程师来说,这是非常有用的。

如何运用本书中的建议

阅读任何关于软件工程的书籍或文章时,一定要记住这是主观的论题,并且对现实问题的 解决方案通常不是完全明晰的。按照我的经验,优秀的工程师总是带着健康的怀疑心态去阅读任 何文章,并渴望理解其中的基本思路。人们的观点各不相同且不断发展,同时可用的工具和编程 语言也在不断改进。想要知道在何时运用特定建议、何时忽略它们,就必须理解它们的缘由、背 景以及限制范围。

本书旨在收集一系列有用的主题和技术,以引导工程师写出更好的代码。尽管考虑这些主题 和技术或许是明智之举,但不应该将其看成绝对正确的理论,或者将其作为绝不能破坏的硬性规 则。良好的判断力是优秀工程师必不可少的特征。

这篇关于软件工程师进入编程世界的55个锦囊:《 好代码 ,坏代码》的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/342492

相关文章

JAVA项目swing转javafx语法规则以及示例代码

《JAVA项目swing转javafx语法规则以及示例代码》:本文主要介绍JAVA项目swing转javafx语法规则以及示例代码的相关资料,文中详细讲解了主类继承、窗口创建、布局管理、控件替换、... 目录最常用的“一行换一行”速查表(直接全局替换)实际转换示例(JFramejs → JavaFX)迁移建

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

MyBatis中的两种参数传递类型详解(示例代码)

《MyBatis中的两种参数传递类型详解(示例代码)》文章介绍了MyBatis中传递多个参数的两种方式,使用Map和使用@Param注解或封装POJO,Map方式适用于动态、不固定的参数,但可读性和安... 目录✅ android方式一:使用Map<String, Object>✅ 方式二:使用@Param

SpringBoot实现图形验证码的示例代码

《SpringBoot实现图形验证码的示例代码》验证码的实现方式有很多,可以由前端实现,也可以由后端进行实现,也有很多的插件和工具包可以使用,在这里,我们使用Hutool提供的小工具实现,本文介绍Sp... 目录项目创建前端代码实现约定前后端交互接口需求分析接口定义Hutool工具实现服务器端代码引入依赖获

利用Python在万圣节实现比心弹窗告白代码

《利用Python在万圣节实现比心弹窗告白代码》:本文主要介绍关于利用Python在万圣节实现比心弹窗告白代码的相关资料,每个弹窗会显示一条温馨提示,程序通过参数方程绘制爱心形状,并使用多线程技术... 目录前言效果预览要点1. 爱心曲线方程2. 显示温馨弹窗函数(详细拆解)2.1 函数定义和延迟机制2.2

Springmvc常用的注解代码示例

《Springmvc常用的注解代码示例》本文介绍了SpringMVC中常用的控制器和请求映射注解,包括@Controller、@RequestMapping等,以及请求参数绑定注解,如@Request... 目录一、控制器与请求映射注解二、请求参数绑定注解三、其他常用注解(扩展)四、注解使用注意事项一、控制

C++简单日志系统实现代码示例

《C++简单日志系统实现代码示例》日志系统是成熟软件中的一个重要组成部分,其记录软件的使用和运行行为,方便事后进行故障分析、数据统计等,:本文主要介绍C++简单日志系统实现的相关资料,文中通过代码... 目录前言Util.hppLevel.hppLogMsg.hppFormat.hppSink.hppBuf

VS Code中的Python代码格式化插件示例讲解

《VSCode中的Python代码格式化插件示例讲解》在Java开发过程中,代码的规范性和可读性至关重要,一个团队中如果每个开发者的代码风格各异,会给代码的维护、审查和协作带来极大的困难,这篇文章主... 目录前言如何安装与配置使用建议与技巧如何选择总结前言在 VS Code 中,有几款非常出色的 pyt

利用Python将PDF文件转换为PNG图片的代码示例

《利用Python将PDF文件转换为PNG图片的代码示例》在日常工作和开发中,我们经常需要处理各种文档格式,PDF作为一种通用且跨平台的文档格式,被广泛应用于合同、报告、电子书等场景,然而,有时我们需... 目录引言为什么选择 python 进行 PDF 转 PNG?Spire.PDF for Python

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关