JavaJDK6学习笔记第15课.pptVIP

  1. 1、本文档共47页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 同步化 同步化确保数据的同步,但所牺性的就是在于一个线程取得对象锁定而占据同步化区块,而其它线程等待它释放锁定时的延迟 wait()、notify() wait()、notify()与notifyAll()是由Object类别所提供的方法 宣告為final 在同步化的方法或区块中呼叫wait()方法 当物件的wait()方法被调用,目前的线程会被放入对象的等待池中,线程归还对象的锁定 其它的线程可竞争对象的锁定 wait()、notify() wait()、notify() 当物件的notify()被调用,它会从目前对象的等待池中通知「一个」线程加入回到锁定池的Blocked状态 被通知的线程是随机的,被通知的线程会与其它线程共同竞争对象的锁定 如果您呼叫notifyAll(),则「所有」在等待池中的线程都会被通知回到锁定池的Blocked状态 wait()、notify() 当线程呼叫到对象的wait()方法时,表示它要先让出对象的锁定并等待通知,或是等待一段指定的时间 被通知或时间到时再与其它线程竞争对象的锁定 如果取得锁定了,就从等待点开始执行 wait()、notify() public synchronized void setProduct(int product) { if(duct != -1) { try { //目前店员没有空间收产品,请稍候! wait(); } catch(InterruptedException e) { e.printStackTrace(); } } duct = product; System.out.printf(生产者设定(%d)%n, duct); //通知等待区中的一个消费者可以继续工作了 notify(); } wait()、notify() public synchronized int getProduct() { if(duct == -1) { try { //缺货了,请稍候! wait(); } catch(InterruptedException e) { e.printStackTrace(); } } int p = duct; System.out.printf(消费者取走(%d)%n, duct); duct = -1; //取走产品,-1表示目前店员手上无产品 //通知等待区中的一个生产者可以继续工作了 notify(); return p; } 容器类的线程安全 可以使用java.util.Collections的synchronizedXXX()等方法来传回一个同步化的容器对象 使用Iterator遍访对象时,您仍必须实作同步化 List list = Collections.synchronizedList(new ArrayList()); List list = Collections.synchronizedList(new ArrayList()); ... synchronized(list) { Iterator i = list.iterator(); while (i.hasNext()) { foo(i.next()); } } ThreadLocal类别 尝试从另一个角度来思考多线程共享资源的问题 共享资源这么困难,那么就干脆不要共享 使用java.lang.ThreadLocal,为每个线程创造一个资源的复本 ThreadLocal类别 public T get() { //取得目前执行get()方法的线程 Thread current = Thread.currentThread(); /

文档评论(0)

xina171127 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档