主页 > 其他  > 

java死锁

java死锁

文章目录

死锁:是指两个或两个以上的进程在执行过程中,因争夺资源而造成的⼀种“相互等待的现象”,若无外力干涉,那它们将都无法推进下去,如果系统资源充足,进程的资源请求都能够得到满足,死锁出现的可能性就很低,否则就会因争夺有限的资源而陷入死锁。 jps指令: jps -l 可以查看运⾏的Java进程 。 jstack指令: jstack pid 可以查看某个Java进程的堆栈信息,同时分析出死锁。

package com.xd; import java.util.concurrent.TimeUnit; class MyData implements Runnable{ private String lockA; private String lockB; public MyData(String lockA, String lockB) { this.lockA = lockA; this.lockB = lockB; } @Override public void run() { synchronized (lockA){ System.out.println(Thread.currentThread().getName()+"\t自己持有"+lockA + "\t尝试获取:" + lockB); try { TimeUnit.SECONDS.sleep(2); } catch (InterruptedException e) { e.printStackTrace(); } synchronized (lockB){ System.out.println(Thread.currentThread().getName()+"\t自己持有"+lockA + "====" + lockB); } } } } public class HoldLockThread { public static void main(String[] args) { String lockA = "lockA"; String lockB = "lockB"; new Thread(new MyData(lockA,lockB),"ThreadA").start(); new Thread(new MyData(lockB,lockA),"ThreadB").start(); } }
标签:

java死锁由讯客互联其他栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“java死锁