多线程学习3-线程互斥与同步通信

1. 线程互斥-synchronized关键字

  a.使用于代码块上:

    synchronized(监视器对象)

    {

      //code

    }

  b.使用于实例方法上:(监视器对象是this

    public synchronized void ff()

    {

    }

  c.使用于静态方法上:(监视器对象是字节码文件,即类名.class

    public static synchronized void ff()

    {

    }

  注意:要想实现互斥,必须保证synchronized的监视器对象相同

 

2.线程同步通信

  需求:子线程循环10次,接着主线程循环100次,再接着子线程循环10次,接着主线程循环100次,如此循环50次。

  思路:将实现循环10次与循环100次的两个方法,构建于一个类中

  代码:

class TraditionalThreadCommunicationDemo
{
	public static void main(String [] args)
	{
		final TraditionalThreadCommunicationDemo.Business business = new TraditionalThreadCommunicationDemo().new Business();
		new Thread(new Runnable(){
			@Override
			public void run()
			{
				for(int i=1;i<51;i++)
				{
					business.sub(i);	
				}	
			}
		}).start();
			
		for(int i=1;i<51;i++)
		{
			business.main(i);	
		}		
	}	
	
	class Business
	{
		private boolean flag = false;
		
		public synchronized void sub(int a)
		{
			while(flag) //使用while比if更健壮
			{
				try
				{
					this.wait(); //实现线程通信1
				}
				catch(Exception e)
				{
					e.printStackTrace();
				}
			}
			
			for(int i=1;i<11;i++)
			{
				System.out.println("sub thread sequence of"+i+",loop of"+a);	
			}
			flag = true;
			this.notify(); //实现线程通信2
		}	
		
		public synchronized void main(int a)
		{
			while(!flag)
			{
				try
				{
					this.wait();
				}
				catch(Exception e)
				{
					e.printStackTrace();
				}
			}
			for(int i=1;i<101;i++)
			{
				System.out.println("main thread sequence of"+i+",loop of"+a);	
			}
			flag = false;
			this.notify();
		}	
	}
}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值