线程同步与互斥量在Linux系统编程中应用.pdfVIP

线程同步与互斥量在Linux系统编程中应用.pdf

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

同步概念

所谓同步,即同时起步,协调一致。不同的对象,对“同步”的理解方式略有不同。如,设备同步,是指在两个设

备之间规定一个共同的时间参考;数据库同步,是指让两个或多个数据库内容保持一致,或者按需要部分保持一致;文

件同步,是指让两个或多个文件夹里的文件保持一致。等等

在编程和通信领域中,同步的概念与日常生活中人们通常理解的同步略有不同。“同”字在这里应理解为协同、协

助和相互配合。其在于协调步调,按照预定的先后顺序运行。

线程同步

同步即协同步调,按预定的先后次序运行。

线程同步,指一个线程发出某能调用时,在没有得到结果之前,该调用不返回。同时其它线程为保证数据一致

性,不能调用该功能。

举例1:存款5000。柜台,折:取3000;提款机,卡:取3000。剩余:2000

举例2:内存中100字节,线程T1欲填入全1,线程T2欲填入全0。但如果T1执行了50个字节失去CPU,T2

执行,会将T1写过的内容覆盖。当T1再次获得CPU继续从失去CPU的位置向后写入1,当执行结束,内存中

的100字节,既不是全1,也不是全0。

这种现象称为“与时间有关的错误”(timerelated)。为了避免这种数据,线程需要同步。

“同步”的目的,是为了避免数据,解决与时间有关的错误。实际上,不仅线程间需要同步,进程间、信号间

等等都需要同步机制。

因此,所有“多个控制流共同操作一个共享资源”的情况都需要同步。

数据:

1.资源共享(独享资源则不会)

2.调度随机(意味着数据会出现竞争)

3.线程间缺乏必要的同步机制。

以上3点中,前两点不能改变,欲提高效率,传递数据,资源必须共享。只要共享资源,就一定会出现竞争。

只要存在竞争关系,数据就很容易出现。

因此只能从第入手解决。当多个线程共享资源时,实现互斥。

互斥量互斥锁

Linux中一把互斥锁mutex(也称之为互斥量)。

每个线程在操作资源前都会尝试先加锁,只有成功加锁后才能进行操作,操作完成后。

资源还是共享的,线程间也还是竞争的,

但是通过“锁”将资源的变为互斥操作后,与时间有关的错误也就不会产生了。

同步概念

所谓同步,即同时起步,协调一致。不同的对象,对“同步”的理解方式略有不同。如,设备同步,是指在两

个设备之间规定一个共同的时间参考;数据库同步,是指让两个或多个数据库内容保持一致,或者按需要部分保持

一致;文件同步,是指让两个或多个文件夹里的文件保持一致。等等

而,编程中、通信中所说的同步与生活中大家印象中的同步概念略有差异。“同”字应是指协同、协助、互相配

合。主旨在协同步调,按预定的先后次序运行。

线程同步

同步即协同步调,按预定的先后次序运行。

线程同步,指一个线程发出某能调用时,在没有得到结果之前,该调用不返回。同时其它线程为保证数据

一致性,不能调用该功能。

举例1:存款5000。柜台,折:取3000;提款机,卡:取3000。剩余:2000

举例2:内存中100字节,线程T1欲填入全1,线程T2欲填入全0。但如果T1执行了50个字节失去cpu,T2

执行,会将T1写过的内容覆盖。当T1再次获得cpu继续从失去cpu的位置向后写入1,当执行结束,内存中的

100字节,既不是全1,也不是全0。

产生的现象叫做“与时间有关的错误”(timerelated)。为了避免这种数据,线程需要同步。

“同步”的目的,是为了避免数据,解决与时间有关的错误。实际上,不仅线程间需要同步,进程间、信

号间等等都需要同步机制。

因此,所有“多个控制流,共同操作一个共享资源”的情况,都需要同步。

数据:

1.资源共享(独享资源则不会)

2.调度随机(意味着数据会出现竞争)

3.线程间缺乏必要的同步机制。

以上3点中,前两点不能改变,欲提高效率,传递数据,资源必须共享。只要共享资源,就一定会出现竞争。

只要存在竞争关系,数据就很容易出现。

所以只能从第着手解决。使多个线程在共享资源的时候,出现互斥。

互斥量mutex

Linux中一把互斥锁mutex(也称之为互斥量

您可能关注的文档

文档评论(0)

152****0921 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档