13.1 概述_第13章 线程安全与锁优化

13.1 概述

在软件业发展的初期,程序编写都是以算法为核心的,程序员会把数据和过程分别作为独立的部分来考虑,数据代表问题空间中的客体,程序代码则用于处理这些数据,这种思维方式直接站在计算机的角度去抽象问题和解决问题,被称为面向过程的编程思想。与此相对,面向对象的编程思想则站在现实世界的角度去抽象和解决问题,它把数据和行为都看作对象的一部分,这样可以让程序员能以符合现实世界的思维方式来编写和组织程序。

面向对象的编程思想极大地提升了现代软件开发的效率和软件可以达到的规模,但是现实世界与计算机世界之间不可避免地存在一些差异。例如,人们很难想象现实中的对象在一项工作进行期间, 会被不停地中断和切换,对象的属性(数据)可能会在中断期间被修改和变脏,而这些事件在计算机世界中是再普通不过的事情。有时候,良好的设计原则不得不向现实做出一些妥协,我们必须保证程序在计算机中正确无误地运行,然后再考虑如何将代码组织得更好,让程序运行得更快。对于本章的主题“高效并发”来说,首先需要保证并发的正确性,然后在此基础上来实现高效。本章就先从如何保证并发的正确性及如何实现线程安全说起。