Java Thread(线程)案例详解sleep和wait的区别
发布时间:2020-12-13 21:20:26 所属栏目:PHP教程 来源:网络整理
导读:学习Java的同学注意了!!! 学习进程中遇到甚么问题或想获得学习资源的话,欢迎加入Java学习交换群,群号码: 183993990 我们1起学Java! F 区分 sleep()方法 sleep()使当前线程进入停滞状态(阻塞当前线程),让出CUP的使用、目的是不让当前线程独自霸占
F区分
sleep()方法
sleep()使当前线程进入停滞状态(阻塞当前线程),让出CUP的使用、目的是不让当前线程独自霸占该进程所获的CPU资源,以留1定时间给其他线程履行的机会;
sleep()是Thread类的Static(静态)的方法;因此他不能改变对象的机锁,所以当在1个Synchronized块中调用Sleep()方法是,线程虽然休眠了,但是对象的机锁并木有被释放,其他线程没法访问这个对象(即便睡着也持有对象锁)。 在sleep()休眠时间期满后,该线程不1定会立即履行,这是由于其它线程可能正在运行而且没有被调度为放弃履行,除非此线程具有更高的优先级。 wait()方法
wait()方法是Object类里的方法;当1个线程履行到wait()方法时,它就进入到1个和该对象相干的等待池中,同时失去(释放)了对象的机锁(暂时失去机锁,wait(long timeout)超时时间到后还需要返还对象锁);其他线程可以访问;
wait()使用notify或notifyAlll或指定睡眠时间来唤醒当前等待池中的线程。 wiat()必须放在synchronized block中,否则会在program runtime时扔出”java.lang.IllegalMonitorStateException“异常。
所以sleep()和wait()方法的最大区分是:
sleep()睡眠时,保持对象锁,依然占有该锁; 而wait()睡眠时,释放对象锁。 但是wait()和sleep()都可以通过interrupt()方法打断线程的暂停状态,从而使线程立刻抛出InterruptedException(但不建议使用该方法)。 F代码
/** * Thread sleep和wait区分 * @author DreamSea * 2012⑴⑴5 */ public class ThreadTest implements Runnable { int number = 10; void firstMethod() throws Exception { synchronized (this) { number += 100; System.out.println(number); } } void secondMethod() this) { * (休息2S,阻塞线程) * 以验证当前线程对象的机锁被占用时,* 是不是被可以访问其他同步代码块 */ Thread.sleep(2000); //this.wait(2000); number *= 200; } } @Override void run() { try { firstMethod(); } catch (Exception e) { e.printStackTrace(); } } static void main(String[] args) throws Exception { ThreadTest threadTest = new ThreadTest(); Thread thread = new Thread(threadTest); thread.start(); threadTest.secondMethod(); } } 使用Wait()方法输出结果:【显示输出】
我们来大致分析1下此段代码,main()方法中实例化ThreadTest并启动该线程,然后调用该线程的1个方法(secondMethod()),由于在主线程中调用方法,所以调用的普通方法secondMethod())会先被履行(但其实不是普通方法履行终了该对象的线程方法才履行,普通方法履行进程中,该线程的方法也会被履行,他们是交替履行的,只是在主线程的普通方法会先被履行而已),所以程序运行时会先履行secondMethod(),而secondMethod()方法代码片断中有synchronized block,因此secondMethod方法被履行后,该方法会占有该对象机锁致使该对象的线程方法1直处于阻塞状态,不能履行,直到secondeMethod释放锁; 使用Thread.sleep(2000)方法时,由于sleep在阻塞线程的同时,并持有该对象锁,所以该对象的其他同步线程(secondMethod())没法履行,直到synchronized block履行终了(sleep休眠终了),secondMethod()方法才可以履行,因此输出结果为number*200+100; 使用this.wait(2000)方法时,secondMethod()方法被履行后也锁定了该对象的机锁,履行到this.wait(2000)时,该方法会休眠2S并释当前持有的锁,此时该线程的同步方法会被履行(由于secondMethod持有的锁,已被wait()所释放),因此输出的结果为:number+100; 【显示流程】 sleep()和wait()方法的区分已讲授终了,若对线程有兴趣的童鞋我在诺诺的问问:在main方法中最后行加入“System.out.println("number="+threadTest.number);”猜猜会输出甚么结果。。。J
学习Java的同学注意了!!!
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |