Java线程间同步通信机制.pdfVIP

  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、同步

这里讲的同步是指多个线程通过synchronized关键字这种方式来实现线程间通信。由于

线程A和线程B持有同一个MyObject类的对象object,尽管这两个线程需要调用不同

的方法,但是它们是同步执行的,比如:线程B需要等待线程A执行完了

methodA()方法,它才能执行methodB()方法。这样,线程A和线程B就实现

了通信。

这种方式,本质上就是“共享内存”式的通信。多个线程需要同一个共享变量,谁拿到

了锁(获得了权限),谁就可以执行。

例如公共类MyObject{synchronized公

共无返回methodA(){//do

something}synchronized公共无返

回methodB(){//dosomeotherthing}}

公共类ThreadA继承线程{private

MyObject对象;//省略构造方法@重写

公共无返回运行(){super.运行();对象.

methodA();}}公共类ThreadB继承线程

{privateMyObject对象;//省略构造方

法@重写公共无返回运行(){super.运

行();对象.methodB();}}

线程间的通信

线程间的通信方式

1、同步

这里讲的同步是指多个线程通过synchronized关键字这种方式来实现线程间的通信。由

于线程A和线程B持有同一个MyObject类的对象object,尽管这两个线程需要调用不

同的方法,但是它们是同步执行的,比如:线程B需要等待线程A执行完了

methodA()方法,它才能执行methodB()方法。这样,线程A和线程B就实现

了通信。

这种方式,本质上就是“共享内存”式的通信。多个线程需要同一个共享变量,谁拿到

了锁(获得了权限),谁就可以执行。

例如

publicclassMyObject{

synchronizedpublicvoidmethodA(){

//dosomething

}

synchronizedpublicvoidmethodB(){

//dosomeotherthing

}

}

publicclassThreadAextendsThread

{privateMyObjectobject;

//省略构造方法

@Override

publicvoidrun()

{super.run();

object.methodA();

}

}

publicclassThreadBextendsThread

{privateMyObjectobject;

//省略构造方法

@Override

publicvoidrun()

{super.run();

object.methodB();

}

}

公共类Run{公共静态无返回主函数(String[]args)

{MyObject对象=newMyObject();//线程A与线程

B持有的是同一个对象:对象线程Aa=new

ThreadA(对象);ThreadBb=newThreadB(对象);a.

启动();b.启动();}}

2、当...的时候轮询的方式

在这种方式下,线程A不断地改变条件,线程ThreadB不停地通过while语句检测这个

条件(list.size()5)是否成立,从而实现了线程间通信。但是这种方式会浪费CPU资

源。之所以说它浪费资源,是因为Java虚拟机调度器将CPU交给线程B执行时,它没做

啥“有用”的工作,只是在不断地测试某个条件是否成立。就类似于现实生活中,

某个人一直看着手机屏幕是否有电话来了,而不是:在干别的事情,

当有电话来时,响铃通知TA电话来了。关于线程的轮询的影响,可参考:

Java多

文档评论(0)

四季豆 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档