7.22_java学习_多线程2

本文探讨了线程之间的通讯机制,通过实例演示了如何利用wait和notify进行线程间的数据传递。此外,还深入讨论了同步函数的概念及其实现方式,并通过案例展示了可能引发的死锁问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一:线程之间的通讯

/*
线程之间的通讯:对共同资源访问
但是操作不同

注意:多个线程同时做一个动作,需要while(falg)判断
notifyAll唤醒。
*/
class res
{
	String name;
	String sex;
	boolean flag = false;
}
class Input implements Runnable
{
	private res r;
	Input(res r)
	{
		this.r = r;
	}
	public void run()
	{
		int x = 0;
		
		while(true)
		{
		 synchronized(r)
			{
			 if(r.flag)
				 try{r.wait();}catch(Exception e){}
				
			if(x == 0)
			{
				r.name = "make";
				r.sex  = "man";
			}
			else
			{
				r.name = "小丽";
				r.sex  = "女";
			}
			x = (x+1)%2;
			r.flag = true;
			r.notify();
		    }
		}
	}
}
class Output implements Runnable
{
	private res r;
	Output(res r)
	{
		this.r = r;
	}
	public void run()
	{
		
		
			while(true)
			{
				synchronized(r)
		        {
			     if(!r.flag)
				 try{r.wait();}catch(Exception e){}
				System.out.println(r.name+"........."+r.sex);
				r.flag = false;
			    r.notify();
			    }
			
		    }
	} 
}
class Thread2 
{
	public static void main(String[] args) 
	{
		res r = new res();
		Input i = new Input(r);
		Output o = new Output(r);

		Thread t1 = new Thread(i);
		Thread t2 = new Thread(o);

		t1.start();
		t2.start();
	}
}


 

二:同步函数

/*
同步函数的锁是this

静态同步方不是this,是类名.class

静态进内存是,内存中没有本类对象,但是一定有该类对应的字节码文件对象。

死锁:
同步中嵌套同步!
*/
class Test
{
	private boolean flag;
	Tead(boolean flag)
	{
		this.flag = flag;
	}

	public void run()
	{
		if(flag)
		{
			synchronized(a)
			{
				System.out.println("if a");
				synchronized(b)
				{
					System.out.println("if b");
				}
			}
		}
		else
		{
			synchronized(b)
			{
				System.out.println("else b");
				synchronized(a)
				{
					System.out.println("else a" );

				}
			}

		}
	}
}
class lack
{
	Object a = new Object();
	Object b = new Object();
}
class MyLock
{
}
class DeadLockTest
{
}
class  Thread3
{
	public static void main(String[] args) 
	{
		Thread t1 = new Thread(new Test(true));
		Thread t2 = new Thread(new Test(false));
		t1.start();
		t2.start();
	}
}


 

java.lang.IllegalStateException: null at com.teamdev.jxbrowser.deps.com.google.common.base.Preconditions.checkState(Preconditions.java:494) ~[jxbrowser-7.22.jar:?] at com.teamdev.jxbrowser.internal.CloseableImpl.checkNotClosed(CloseableImpl.java:35) ~[jxbrowser-7.22.jar:?] at com.teamdev.jxbrowser.browser.internal.DragAndDrop.isEnabled(DragAndDrop.java:38) ~[jxbrowser-7.22.jar:?] at com.teamdev.jxbrowser.view.javafx.internal.OffScreenRenderWidget.isDragAndDropEnabled(OffScreenRenderWidget.java:303) ~[jxbrowser-javafx-7.22.jar:?] at com.teamdev.jxbrowser.view.javafx.internal.OffScreenRenderWidget.show(OffScreenRenderWidget.java:320) ~[jxbrowser-javafx-7.22.jar:?] at com.teamdev.jxbrowser.view.javafx.internal.IoSurfaceRenderWidget.show(IoSurfaceRenderWidget.java:83) ~[jxbrowser-javafx-7.22.jar:?] at com.teamdev.jxbrowser.view.javafx.internal.OffScreenRenderWidget.showIfVisible(OffScreenRenderWidget.java:315) ~[jxbrowser-javafx-7.22.jar:?] at com.teamdev.jxbrowser.view.javafx.internal.OffScreenRenderWidget.setWindow(OffScreenRenderWidget.java:241) ~[jxbrowser-javafx-7.22.jar:?] at com.teamdev.jxbrowser.view.javafx.internal.OffScreenRenderWidget.access$2100(OffScreenRenderWidget.java:77) ~[jxbrowser-javafx-7.22.jar:?] at com.teamdev.jxbrowser.view.javafx.internal.OffScreenRenderWidget$SceneChangeListener.setScene(OffScreenRenderWidget.java:626) ~[jxbrowser-javafx-7.22.jar:?] at com.teamdev.jxbrowser.view.javafx.internal.OffScreenRenderWidget$SceneChangeListener.lambda$changed$0(OffScreenRenderWidget.java:615) ~[jxbrowser-javafx-7.22.jar:?] at com.sun.javafx.application.PlatformImpl.lambda$null$172(PlatformImpl.java:295) ~[jfxrt.jar:?] at java.security.AccessController.doPrivileged(Native Method) ~[?:1.8.0_191] at com.sun.javafx.application.PlatformImpl.lambda$runLater$173(PlatformImpl.java:294) ~[jfxrt.jar:?] at com.sun.glass.ui.InvokeLaterDispatcher$Future.run$$$capture(InvokeLaterDispatcher.java:95) ~[jfxrt.jar:?] at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java) ~[jfxrt.jar:?]
03-28
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值