java中的锁池和等待池 (r)
来源:互联网 发布:mac pretty boy 编辑:程序博客网 时间:2024/06/05 06:40
在java中,每个对象都有两个池,锁(monitor)池和等待池
wait() ,notifyAll(),notify() 三个方法都是Object类中的方法.
锁池:假设线程A已经拥有了某个对象(注意:不是类)的锁,而其它的线程想要调用这个对象的某个synchronized方法(或者synchronized块),由于这些线程在进入对象的synchronized方法之前必须先获得该对象的锁的拥有权,但是该对象的锁目前正被线程A拥有,所以这些线程就进入了该对象的锁池中。
等待池:假设一个线程A调用了某个对象的wait()方法,线程A就会释放该对象的锁(因为wait()方法必须出现在synchronized中,这样自然在执行wait()方法之前线程A就已经拥有了该对象的锁),同时线程A就进入到了该对象的等待池中。如果另外的一个线程调用了相同对象的notifyAll()方法,那么处于该对象的等待池中的线程就会全部进入该对象的锁池中,准备争夺锁的拥有权。如果另外的一个线程调用了相同对象的notify()方法,那么仅仅有一个处于该对象的等待池中的线程(随机)会进入该对象的锁池.
下面通过一个例子来说明:
要求写两个线程,一个线程将某个对象的某个成员变量的值加1,而另外一个线程将这个成员变量的值减1.使得该变量的值始终处于[0,2].初始值为0.
在java中,每个对象都有两个池,锁(monitor)池和等待池
wait() ,notifyAll(),notify() 三个方法都是Object类中的方法.
锁池:假设线程A已经拥有了某个对象(注意:不是类)的锁,而其它的线程想要调用这个对象的某个synchronized方法(或者synchronized块),由于这些线程在进入对象的synchronized方法之前必须先获得该对象的锁的拥有权,但是该对象的锁目前正被线程A拥有,所以这些线程就进入了该对象的锁池中。
等待池:假设一个线程A调用了某个对象的wait()方法,线程A就会释放该对象的锁(因为wait()方法必须出现在synchronized中,这样自然在执行wait()方法之前线程A就已经拥有了该对象的锁),同时线程A就进入到了该对象的等待池中。如果另外的一个线程调用了相同对象的notifyAll()方法,那么处于该对象的等待池中的线程就会全部进入该对象的锁池中,准备争夺锁的拥有权。如果另外的一个线程调用了相同对象的notify()方法,那么仅仅有一个处于该对象的等待池中的线程(随机)会进入该对象的锁池.
下面通过一个例子来说明:
要求写两个线程,一个线程将某个对象的某个成员变量的值加1,而另外一个线程将这个成员变量的值减1.使得该变量的值始终处于[0,2].初始值为0.
- package com.tju;
- class Target
- {
- private int count;
- public synchronized void increase()
- {
- if(count == 2)
- {
- try
- {
- wait();
- }
- catch (InterruptedException e)
- {
- e.printStackTrace();
- }
- }
- count++;
- System.out.println(Thread.currentThread().getName() + ":" + count);
- notify();
- }
- public synchronized void decrease()
- {
- if(count == 0)
- {
- try
- {
- //等待,由于Decrease线程调用的该方法,
- //所以Decrease线程进入对象t(main函数中实例化的)的等待池,并且释放对象t的锁
- wait();//Object类的方法
- }
- catch (InterruptedException e)
- {
- e.printStackTrace();
- }
- }
- count--;
- System.out.println(Thread.currentThread().getName() + ":" + count);
- //唤醒线程Increase,Increase线程从等待池到锁池
- notify();
- }
- }
- class Increase extends Thread
- {
- private Target t;
- public Increase(Target t)
- {
- this.t = t;
- }
- @Override
- public void run()
- {
- for(int i = 0 ;i < 30; i++)
- {
- try
- {
- Thread.sleep((long)(Math.random()*500));
- }
- catch (InterruptedException e)
- {
- e.printStackTrace();
- }
- t.increase();
- }
- }
- }
- class Decrease extends Thread
- {
- private Target t;
- public Decrease(Target t)
- {
- this.t = t;
- }
- @Override
- public void run()
- {
- for(int i = 0 ; i < 30 ; i++)
- {
- try
- {
- //随机睡眠0~500毫秒
- //sleep方法的调用,不会释放对象t的锁
- Thread.sleep((long)(Math.random()*500));
- }
- catch (InterruptedException e)
- {
- e.printStackTrace();
- }
- t.decrease();
- }
- }
- }
- public class Test
- {
- public static void main(String[] args)
- {
- Target t = new Target();
- Thread t1 = new Increase(t);
- t1.setName("Increase");
- Thread t2 = new Decrease(t);
- t2.setName("Decrease");
- t1.start();
- t2.start();
- }
- }
- java中的锁池和等待池 (r)
- java中的锁池和等待池
- java中的锁池和等待池
- java中的锁池和等待池
- Java中的等待池和锁池
- java的锁池和等待池wait notify notifyall
- Java中的回车(\r)和换行(\n)
- Java常用面试题15 synchronized方法的妙用 锁池和等待池的区别
- java中的互斥锁,信号量和多线程等待机制
- java中的互斥锁,信号量和多线程等待机制
- java 的wait(),sleep()及锁池与等待池
- sleep()和wait()方法与对象锁、锁池、等待池
- java 等待线程/线程池执行完毕
- JAVA线程池的分析和使用(r)
- java交互:通知和等待
- 多线程编程中的等待/通知机制和等待超时模式
- 查看锁和等待
- Java 编程下 CyclicBarrier 中的线程等待
- 利用jquery实现百度新闻导航菜单滑动动画
- Service高级进阶
- Effective Modern C++ 条款17 理解特殊成员函数的生成
- zookeeper集群安装配置
- Linux 信号
- java中的锁池和等待池 (r)
- SolrJ
- B-spline Curves 学习之B样条曲线性质(5)
- JAVA设计模式之单例模式
- 分布式缓存技术redis学习系列(一)——redis简介以及linux上的安装以及操作redis问题整理
- IOS your app stores 18.79MB on the user's iCloud 应用被拒问题,
- jvm内存溢出解决办法
- Java中的异常 Exception
- B-spline Curves 学习之B样条曲线的系数计算与B样条曲线特例(6)