zoukankan      html  css  js  c++  java
  • java多线程之 ---- 线程死锁

    java多线程之线程死锁


    产生死锁的主要原因:

    • 由于系统资源不足。 
    • 进程执行推进的顺序不合适。 
    • 资源分配不当等。 

    假设系统资源充足。进程的资源请求都可以得到满足,死锁出现的可能性就非常低。否则就会因争夺有限的资源而陷入死锁。其次,

    进程执行推进顺序与速度不同,也可能产生死锁。 


    产生死锁的四个必要条件: 

    • 相互排斥条件:一个资源每次仅仅能被一个进程使用。 
    • 请求与保持条件:一个进程因请求资源而堵塞时,对已获得的资源保持不放。

       

    • 不剥夺条件:进程已获得的资源。在末使用完之前。不能强行剥夺。 
    • 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。

       

    这四个条件是死锁的必要条件。仅仅要系统发生死锁,这些条件必定成立,而仅仅要上述条件之中的一个不满足,就不会发生死锁。 


    演示样例:

    package com.lock;
    
    public class Test implements Runnable {
    	public int flag = 1;
    	static Object obj1 = new Object(), obj2 = new Object();
    
    	public void run() {
    		System.out.println("flag= " + flag);
    
    		if (flag == 1) {
    			synchronized (obj1) {
    				try {
    					Thread.sleep(500);
    				} catch (InterruptedException e) {
    					e.printStackTrace();
    				}
    				synchronized (obj2) {
    					System.out.println("1");
    				}
    			}
    		}
    
    		if (flag == 0) {
    			synchronized (obj2) {
    				try {
    					Thread.sleep(500);
    				} catch (InterruptedException e) {
    					// TODO Auto-generated catch block
    					e.printStackTrace();
    				}
    				synchronized (obj1) {
    					System.out.println("0");
    				}
    			}
    		}
    	}
    
    	public static void main(String[] args) {
    		Test td1 = new Test();
    		Test td2 = new Test();
    		td1.flag = 1;
    		td2.flag = 0;
    		Thread t1 = new Thread(td1);
    		Thread t2 = new Thread(td2);
    
    		t1.start();
    		t2.start();
    	}
    
    }



  • 相关阅读:
    [CQOI2005]三角形面积并(计算几何+扫描线)
    第一天
    LA3026 周期 (kmp)
    HDU 1715 大菲波数 (java大数)
    根据身高重建队列(vector)
    K 连续位的最小翻转次数
    724. Find Pivot Index
    Two Sum
    c
    Most Powerful(状压DP水题)
  • 原文地址:https://www.cnblogs.com/wzzkaifa/p/7137620.html
Copyright © 2011-2022 走看看