Java - 死锁

/*
	死锁就是两个线程都被挂起,在等待区。程序终结
	
	线程1,实现的任务,先打开锁1,再打开锁2
	线程2,实现的任务,先打开锁2,再打开锁1
	线程1进入锁1,CPU切换线程2,线程2进入锁2;挂起等待。CPU切换线程1,挂起等待。

	线程1,实现的任务,先打开锁1,再打开锁2,打开锁2,再打开锁1,
	线程2,实现的任务,先打开锁1,再打开锁2,打开锁2,再打开锁1,
	线程1进入锁2,CPU切换线程2,线程2进入锁1;挂起等待。CPU切换线程1,挂起等待。

*/
class ThreadDemo 
{
	public static void main(String[] args) 
	{
		//die1 die1Run = new die1();
		die2 die2Run = new die2();
		//new Thread(die1Run,"d1").start();
		//die1Run.flag=false;
		//new Thread(die1Run,"d2").start();
		new Thread(die2Run,"d3").start();		
		new Thread(die2Run,"d4").start();		
		System.out.println("Hello World!");
	}
}
/*
class die1 implements Runnable
{
	private int num=20;
	boolean flag=true;	
	public void run(){
		if(flag){
			while(true)
			{
				synchronized(NewThread.class){				
					printNum();
				}
			}
		}else{
			while(true)
			{
				printNum();
			}
		}		
	}
	public synchronized void printNum(){		
		synchronized(NewThread.class){
			if(num>10){							
				System.out.println(num-- + "--" + Thread.currentThread().getName());				
			}
		}		
	}
}
*/
class die2 implements Runnable
{
	private int num=10;
	public void run(){
		while(true)
		{
			synchronized(NewThread.class){				
				printNum();
			}
			printNum();
		}		
	}
	public synchronized void printNum(){
		synchronized(NewThread.class){
			if(num>0){		
				for(int i=0;i<10000;i++){}
				System.out.println(num-- + "--" + Thread.currentThread().getName());				
			}
		}
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java和Linux都是非常常用的软件开发工具。但是,无论是Java还是Linux都存在可能导致的情况。 在Java中,是指两个或多个线程相互等待对方持有的资源,而导致所有线程都无法继续执行的情况。这通常发生在多线程编程中,当多个线程尝试以不同的顺序定多个资源时,可能会导致。例如,线程A持有资源X并等待获取资源Y,而线程B持有资源Y并等待获取资源X,这样就会导致。 在Linux中,是指多个进程或线程由于争夺有限的系统资源而无限期地相互等待对方释放资源的情况。这种情况通常发生在系统资源(如内存、文件描述符等)不足时,多个进程或线程同时请求这些资源,但由于资源分配不当而无法满足所有请求,从而导致。 对于Java中的,可以通过使用的合理顺序、避免使用多个或使用的超时机制来预防。另外,通过使用工具如检测的工具(如jstack)可以帮助发现和解决问题。 对于Linux中的,可以通过合理规划和分配系统资源、采用进程/线程优先级策略、使用资源分配算法等手段来避免。此外,Linux内核还提供了一些检测和解决方法,如通过/sysfs下的文件system下的文件deadlock_detection来检测和解决。 总之,无论是Java还是Linux,都是需要引起关注的问题,但通过合理的设计和调优,我们可以最大程度地避免的发生,并保证系统的稳定性和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值