java多线程编程离不开锁,和锁管的几个函数有wait,notify,sleep,join等
首先来看这个几个方法的结构以及所在的类
wait和notify以及notifyAll 都是在java的超类Object里面,这样设计的目的,个人见解可能是实现面向对象的需要,把每个对象都放在jvm的等待队列里面
sleep和join 都是在类thread中
作用:
sleep()方法 : 使当前线程进入停滞状态(阻塞当前线程),让出CUP的使用、目的是不让当前线程独自霸占该进程所获的CPU资源,以留一定时间给其他线程执行的机会;
sleep()是Thread类的Static(静态)的方法;因此他不能改变对象的机锁,所以当在一个Synchronized块中调用Sleep()方法是,线程虽然休眠了,但是对象的机锁并木有被释放,其他线程无法访问这个对象(即使睡着也持有对象锁)。
在sleep()休眠时间期满后,该线程不一定会立即执行,这是因为其它线程可能正在运行而且没有被调度为放弃执行,除非此线程具有更高的优先级。
wait()方法 : Object类里的方法;当一个线程执行到wait()方法时,它就进入到一个和该对象相关的等待池中,同时失去(释放)了对象的机锁(暂时失去机锁,wait(long timeout)超时时间到后还需要返还对象锁);其他线程可以访问;
wait()使用notify或者notifyAlll或者指定睡眠时间来唤醒当前等待池中的线程。
wiat()必须放在synchronized block中,否则会在program runtime时扔出出”java.lang.IllegalMonitorStateException“异常
notify以及notifyAll:唤醒该对象等待池中的对象继续执行工作
Join:必须在线程调用start方法之后才能调用,不然则不起作用,具体的可以查看jvm的thread的源码,join方法的作用就是等待某个线程的终止
需要注意的是notify和wait的实现,必须有对象锁的实现,不然就会爆出IllegalMonitorStateException异常
以下为用wait以及notify实现的消费者-生产者的例子
/**
* QueueBuffer.java Create on 2014年8月5日
*
* Copyright (c) 2014年8月5日 by dzh
*
* @author <a href="xingyu@gw.com.cn">xingyu</a>
* @version 0.0.1
*
*/
package org.dzh.thread.setAndget;
/**@className:QueueBuffer.java
* @description:消费池子队列
* @date 2014年8月5日 下午4:48:26
*/
public class QueueBuffer {
private int num;
/**是否被设置值*/
private boolean valueSet = false;
synchronized int get(){
if(!valueSet){
try {
wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
valueSet = false;
notify();
return num;
}
synchronized void set(int n){
if(valueSet){
try {
wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
valueSet = true;
notify();
this.num = n;
}
}
/**
* Product.java Create on 2014年8月5日
*
* Copyright (c) 2014年8月5日 by dzh
*
* @author <a href="xingyu@gw.com.cn">xingyu</a>
* @version 0.0.1
*
*/
package org.dzh.thread.setAndget;
/**@className:Product.java
* @description:生产者
* @date 2014年8月5日 下午4:57:25
*/
public class Product extends Thread{
private QueueBuffer qb;
public Product(QueueBuffer qb,String name){
super(name);
this.qb = qb;
}
@Override
public void run() {
int num = 1;
for (; ; ) {
qb.set(num);
num++;
}
}
}
/**
* Consumer.java Create on 2014年8月5日
*
* Copyright (c) 2014年8月5日 by dzh
*
* @author <a href="xingyu@gw.com.cn">xingyu</a>
* @version 0.0.1
*
*/
package org.dzh.thread.setAndget;
/**@className:Consumer.java
* @description:消费者
* @date 2014年8月5日 下午4:57:49
*/
public class Consumer extends Thread{
private QueueBuffer qb;
public Consumer(QueueBuffer qb,String name){
super(name);
this.qb = qb;
}
@Override
public void run() {
System.out.println(qb.get());
}
}
相关推荐
分享的多线程技术不是告诉你什么是线程,线程的状态,而是我们在开发中容易踩的坑,受过的伤害。我不会告诉你什么是爱情,但是我会告诉你爱过。 一 基础: 1,Thread.sleep(0)的作用 2,为什么线程会带来性能问题 3...
多线程锁 并发下的集合类 List Set Map Callable接口 线程创建的方式 callable / runnable FutureTask JUC常用辅助类 CountDownLatch (减少计数器) CyclicBarrier(加法计数器) Semaphore(信号量,流量控制) ...
【多线程】sleep()和wait()分别是哪个类的方法,有什么区别? 79 【多线程】sleep()和yield()的区别 79 【多线程】对synchronized理解?用在代码块和方法上有什么区别? 80 【多线程】Volatile的理解 82 【*多线程】...
update() 在线程同步中,为了唤醒另一个等待的线程,使用下列方法 () [单选题] * A.sleep() B.wait() C.notify()(正确答案) D. join() Java高级程序设计测试含答案全文共40页,当前为第4页。Java提供以下哪个...
│ 高并发编程第二阶段04讲、多线程的休息室WaitSet详细介绍与知识点总结.mp4 │ 高并发编程第二阶段05讲、一个解释volatile关键字作用最好的例子.mp4 │ 高并发编程第二阶段06讲、Java内存模型以及CPU缓存不一致...
│ 高并发编程第二阶段04讲、多线程的休息室WaitSet详细介绍与知识点总结.mp4 │ 高并发编程第二阶段05讲、一个解释volatile关键字作用最好的例子.mp4 │ 高并发编程第二阶段06讲、Java内存模型以及CPU缓存不一致...
A.sleep() B.notify() C.wait() D.join() 正确答案:B 您的答案: 本题解析: 暂无解析 2.以下标识符中,不是Java语言关键字的是()。 A.wait B.new C.long D.switch 正确答案:A 您的答案: 本题解析: 暂无解析 3....
LeetCode判断字符串是否循环 知识点总结 java基础 1、使用迭代器和for each循环查看集合元素时只能获得元素的值,不能改变元素 ...object的方法:wait(notify,notifyall),thread的方法:(sleep、join),结束
Java程序.............................................................................................6 1.3.1 Java程序的结构 ...........................................................................
25 JAVA8 与元数据.................................................................................................................................25 2.4. 垃圾回收与算法 .................................
25 JAVA8 与元数据.................................................................................................................................25 2.4. 垃圾回收与算法 .................................