一、同步概念
所谓同步,即同时起步,协调一致。不同的对象,对“同步”的理解方式略有不同,如,设备文件,是指两个设备之间规定一个时间参考;数据库同步,是指让两个或多个数据库内容保持一致,或按需要部分保持一致;文件同步,是指让两个或多个文件夹里的文件保持一致。
二、线程同步
同步即协同步调,按预定的先后次序运行。
线程同步:指一个线程发出某一个功能调用,在没有得到结果之前,该调用不返回,同时其他线程为保证数据一致性,不能调用该功能。
- 举例1:银行存款5000,柜台,存折:取3000;提款机,银行卡:取3000,剩余2000。
- 举例2:内存中100字节,线程T1欲填全1,线程T2欲填入全0。但如果T1执行了50个失去CPU,T2执行,会将T1写过的内容覆盖,当T1再次获得CPU继续,从失去CPU的位置向后写入1,当执行结束,内存中的100字节,既不是全1, 也不是全0。
产生的现象叫做“与时间有关的错误”,为避免这种数据混乱,线程需要同步。
“同步”的目的,是为了避免数据错误,解决与时间有关的错误,实际上,不仅线程需要同步,进程间、信号间等等都需要同步机制。
因此,所有“多个控制流,共同操作一个共享资源”的情况,都需要同步。