多线程死锁问题(this锁和普通锁区别)

本文通过一个实例演示如何创建一个多线程死锁程序,探讨了在Java中this锁(即对象锁)与普通同步代码块锁的区别,以及在实现任务切换时可能导致死锁的情况。
摘要由CSDN通过智能技术生成

需求:写一个多线程死锁程序。

思路:1、创建一个类Test 实现Runnable接口,并把任务封装到run()方法中。

2、任务代码中用到两个同步代码块,并实现任务切换,来实现死锁。

3,或者用同步函数和同步代码块,但能发现this锁的特殊。

第一种方法是,用两个同步代码块嵌套,来实现死锁。
package cm;

public class DeadLock {
	public static void main(String []args){

		Test t=new Test();
		Thread s=new Thread(t,"one");
		Thread s1=new Thread(t,"two");
		s.start();
		try {
			Thread.sleep(10);
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		t.flag=false;
		s1.start();
		
	}

}
class Test implements Runnable{
	boolean flag=true;
	Object obj =new Object();
	Object obj1 =new Object();
	public void run() {
		if(flag)
		{
			while(true)
			{	synchronized(obj){
				
				System.out.println(Thread.currentThread()+"...lock obj.....");
				try {
					Thread.sleep(10);
				} catch (InterruptedException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
				synchronized(obj1){
					System.out.println(Thread.currentThread()+".....lock obj1.....");
				}
			}
				
			}
			
		}
		else 
			while(true)
			show();
		
	
		
	}
	private  void show() {
		synchronized(obj1){
                System.out.println(Thread.currentThread()+"obj1 lock....");
		synchronized(obj){
			System.out.println(Thread.currentThread()+"obj lock.....");
			
			
		}
		}
	}
	
}



第二种死锁方式:
同步函数和同步代码块嵌套,可以发现的不同之处是。this锁由于是指向本类对象,故可以被同一个对象调用的同步函数同时持有
,而不排斥,普通锁只能被一个所持有,也就是说,s线程拿到了this锁同时,不影响s1线程拿到this锁。。package cm;

public class DeadLock {
	public static void main(String []args){

		Test t=new Test();
		Thread s=new Thread(t,"one");
		Thread s1=new Thread(t,"two");
		s.start();
		try {
			Thread.sleep(10);
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		t.flag=false;
		s1.start();
		
	}

}
class Test implements Runnable{
	boolean flag=true;
	Object obj =new Object();
	
	public void run() {
		if(flag)
		{
			while(true)
			{	
				synchronized(obj){
				
				System.out.println(Thread.currentThread()+"...lock obj.....");
				  try {
					Thread.sleep(10);
				    }  
				  catch (InterruptedException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
				  show();
			
			}
				
			}
			
		}
		else 
			while(true)
			show();
		
	
		
	}
	private  void show() {
		
                System.out.println(Thread.currentThread()+"this lock....");
		synchronized(obj){
			System.out.println(Thread.currentThread()+"obj lock.....");
			
			
		}
		}
	}
	


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值