《并发编程》--4.线程等待(wait)和线程通知(notity)

本文深入探讨了Java并发编程中的线程等待(wait)和线程通知(notify)方法,这两个方法属于Object类。线程调用wait()后会在对象上等待,直到其他线程执行notify()进行唤醒。线程的唤醒是随机的,不保证公平,且wait()必须在同步块中调用。此外,还提到了notifyAll()方法,用于唤醒所有等待的线程。示例代码帮助读者更好地理解这些概念。

    为了支持多线程之间的操作,jdk提供了线程等待(wait)和线程通知(notity)两个非常重要的方法,这两个方法是来自object类而不是thread类中。所以任何对象都可以调用这两个方法 。

    当一个对象调用了wait()方法后,当前线程就会在这个对象上等待,直至其他线程调用了notity(),这就是线程之间的通信手段

    如果一个线程调用了obj.wait(),它就会计入object对象的等待队列,在这个队列中,可能有多个线程,因为系统运行多个线程同时等待某一个对象。当object.notity()被调用时,它就会在这个等待的队列中,随机选择一个线程,并将其唤醒。

   注意:1.这个唤醒是不公平的,不遵循先进先出,完全是随机的

                2.wai()方法不是随便可以调用的,必须包含在synchronizied语句中

    除notity()外,还有一个类似的方法notityAll(),顾名思义,就是唤醒所有等待的线程

   为了方法理解,以下是一个简单的demo

public class waitAndNotity {
	final static Object object  = new Object();
	public static class T1 extends Thread{
		public void run(){
			synchronized (object) {//声明对象所
				System.out.println(System.currentTimeMillis()+":T1  start");
			try {
				System.out.println(System.currentTimeMillis()+"T1 wait for object");
				object.wait();
			} catch (InterruptedException e) {
				// TODO: handle exception
				e.printStackTrace();
			}
			System.out.println(System.currentTimeMillis()+":T1 end!");
			}
		}
	}

	public static class T2 extends Thread{
		public void run(){
			synchronized (object) { //声明对象所
				System.out.println(System.currentTimeMillis()+":T2 start!notity one thread ");
				object.notify();
				System.out.println(System.currentTimeMillis()+": T2 end!");
				try {
					Thread.sleep(2000);//测试,为了让效果更明显
				} catch (InterruptedException e) {
					// TODO: handle exception
					e.printStackTrace();
				}
			}
		}
	}
	
	public static void main(String[] args) {
		Thread t1 = new T1();
		Thread t2 = new T2();
		t1.start();
		t2.start();
	}
运行结果如下:

1502950336523:T1  start
1502950336523T1 wait for object
1502950336523:T2 start!notity one thread 
1502950336523: T2 end!
1502950338523:T1 end!

有兴趣的可以继续查看下一节------线程挂起(susend)和通知(resume)

09-10 11:18:11.121 04902 05440 I SystemUi--Keyguard: PictorialWallpaperLoader-->processLoadWallpaperReq Filepath pictorial-inlay-resID:2131231843 09-10 11:18:11.122 07094 07094 D AntiTheftManager: USB connection set to Charging Only now. 09-10 11:18:11.122 02967 04752 D DisplayAdapterExt: sendDisplayDeviceEventLocked event=2,now=58130567,timestamp=58130567 device:[id=local:4630946996568193153,stack=-1],isFirst=true,activeMode=1,state=ON,commitState=OFF,devInfo:null 09-10 11:18:11.122 04902 04902 D SystemUi--Keyguard: KeyguardClockPositionAl-->ClockPosition, canScaleFadePanel:false, mPanelExpansion:1.0, originalPanelExpansion:1.0, finalPanelExpansion:1.0, usePanelAnimFraction:false, panelAnimFraction:1.0, mQsExpansion:0.0, isQsVisible:false, mUnlockedStackScrollerPadding:366, mKeyguardStatusHeight:385, mStatusViewBottomMargin:72, mMinTopMargin:264, clockY:264, userSwitchY:120, clockYFullyDozing:231, clockAlpha:1.0, stackScrollerPadding:649, stackScrollerPaddingExpanded:649, clockX:0, clockScale:1.0, emptyDragAmount:0.0, isSplitShade:false, hintRunning:false, isNotiWorkshopRun:false, notiTY:0 09-10 11:18:11.122 02967 04752 D OplusSmartBrightnessController: requestDisplayState isFirstDisplay=true state=2 globalDisplayState=0x2 09-10 11:18:11.122 02967 03011 D DisplayDeviceRepositoryExtImpl: onDisplayDeviceEvent event=2,now=58130567,timestamp=58130567 device:[id=local:4630946996568193153,stack=-1],isFirst=true,activeMode=1,state=ON,commitState=OFF,devInfo:null 09-10 11:18:11.122 02967 04752 D DisplayDeviceExt: setDisplayState([4630946996568193153,true],OFF->ON),t-Name=PhotonicModulator 09-10 11:18:11.122 01427 01427 I QTI PowerHAL: Power setMode: 7 to: 1 09-10 11:18:11.123 01591 01789 D nwatchcall: ignoreCaptrueAndReport 0 09-10 11:18:11.123 01591 01591 I OplusSurfaceFlinger: Setting power mode 2 on display 4630946996568193153, called from 2967 09-10 11:18:11.123 01591 01591 D SurfaceFlinger: Setting power mode 2 on display 4630946996568193153 09-10 11:18:11.123 02967 03011 I DisplayDeviceRepository: Display device changed state: "内置屏幕", ON 09-10 11:18:11.123 04902 04902 D SystemUi--Keyguard: OplusKeyguardGaiaManager-->onEvent(101316) start 09-10 11:18:11.123 04902 04902 I SystemUi--Keyguard: PictorialWallpaperHelper-->onScreenTurningOn 09-10 11:18:11.123 04902 04902 D SystemUi--Keyguard: LockDeadUtil-->sendScreenOnBroadcast() not support find phone occluded view! 09-10 11:18:11.123 02967 03008 D UsbDeviceManager: setEnabledFunctions [functions= ,forceRestart=false ,usbDataUnlocked=false ,mUsbDataUnlocked=false ,operationId=1005] 09-10 11:18:11.123 01591 01920 I OplusDEE: handleDEE: 0x00040001 09-10 11:18:11.124 02967 03008 D UsbDeviceManager: oplusFunctions: diag,adb 09-10 11:18:11.124 01591 01591 D SurfaceFlinger: setSchedFifo : enable = 1分析一下为什么设置了charging only后到底层还是传了diag,adb
最新发布
09-13
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值