【好记性不如烂笔头】死锁之java代码

简介: 死锁: 是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。

死锁: 是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。

 1 public class DeadLock {
 2     public static void main(String[] args) {
 3         MyThread m=new MyThread();
 4         /*创建两个线程*/
 5         Thread t1=new Thread(m);
 6         Thread t2=new Thread(m);
 7         /*线程开始运作*/
 8         t1.start();
 9         t2.start();
10     }
11 
12 }
13 class MyThread implements Runnable{
14     /*设立标志位,目的是让两个线程分别进入if-else的两个分支*/
15     public boolean flag=true;
16     @Override
17     public void run() {
18         // TODO Auto-generated method stub
19         if(flag){
20             /*flag一开始为真,线程t1进入if分支,然后讲flag置假,让接下来的线程进入else分支*/
21             flag=false;
22             while(true)
23                 synchronized (this) {
24                     synchronized (this.getClass()) {
25                         System.out.println(Thread.currentThread().getName()+"true");
26                         try { Thread.sleep(50); } catch (Exception e) {  e.printStackTrace();  } 
27                     }
28                 }
29         }else{
30             /*t2线程进入该分支,进入死循环*/
31             while(true)
32                 synchronized (this.getClass()) {
33                     synchronized (this) {
34                         System.out.println(Thread.currentThread().getName()+"false");
35                         try { Thread.sleep(50); } catch (Exception e) {  e.printStackTrace();  } 
36                     }
37                 }
38         }
39     }
40     
运行结果:
1
Thread-0true 2 Thread-0true 3 Thread-0true 4 Thread-0true 5 Thread-1false 6 Thread-0true 7 Thread-0true 8 Thread-0true 9 Thread-0true 10 Thread-1false 11 Thread-1false 12 Thread-0true 13 Thread-0true 14 Thread-0true 15 Thread-0true 16 Thread-0true 17 Thread-1false

实现死锁的思路:两个线程,分别进入AB两个分支,AB分支的锁是互相嵌套的,设立线程休眠的点应该拥有这样的情况,A拥有B的锁,B拥有A的锁,来吧~互相伤害,哈哈。

黑夜给了我黑色的眼睛,我却用它寻找光明
目录
相关文章
|
11天前
|
Java 测试技术 应用服务中间件
常见 Java 代码缺陷及规避方式(下)
常见 Java 代码缺陷及规避方式(下)
33 0
|
13天前
|
Java
Java中ReentrantLock释放锁代码解析
Java中ReentrantLock释放锁代码解析
25 8
|
16天前
|
前端开发 小程序 Java
uniapp上传图片 前端以及java后端代码实现
uniapp上传图片 前端以及java后端代码实现
30 0
|
18天前
|
设计模式 存储 Java
23种设计模式,享元模式的概念优缺点以及JAVA代码举例
【4月更文挑战第6天】享元模式(Flyweight Pattern)是一种结构型设计模式,旨在通过共享技术有效地支持大量细粒度对象的重用。这个模式在处理大量对象时非常有用,特别是当这些对象中的许多实例实际上可以共享相同的状态时,从而可以减少内存占用,提高程序效率
31 4
|
18天前
|
设计模式 Java 中间件
23种设计模式,适配器模式的概念优缺点以及JAVA代码举例
【4月更文挑战第6天】适配器模式(Adapter Pattern)是一种结构型设计模式,它的主要目标是让原本由于接口不匹配而不能一起工作的类可以一起工作。适配器模式主要有两种形式:类适配器和对象适配器。类适配器模式通过继承来实现适配,而对象适配器模式则通过组合来实现
30 4
|
19天前
|
存储 缓存 算法
优化 Java 后台代码的关键要点
【4月更文挑战第5天】本文探讨了优化 Java 后台代码的关键点,包括选用合适的数据结构与算法、减少不必要的对象创建、利用 Java 8 新特性、并发与多线程处理、数据库和缓存优化、代码分析与性能调优、避免阻塞调用、JVM 调优以及精简第三方库。通过这些方法,开发者可以提高系统性能、降低资源消耗,提升用户体验并减少运营成本。
|
20天前
|
Java 开发工具 流计算
flink最新master代码编译出现Java Runtime Environment 问题
在尝试编译Flink源码时遇到Java运行时环境致命错误:EXCEPTION_ACCESS_VIOLATION。问题出现在JVM.dll+0x88212。使用的是Java 11.0.28和Java HotSpot(TM) 64-Bit Server VM。系统为Windows客户端,没有生成核心dump文件。错误日志保存在hs_err_pid39364.log和replay_pid39364.log。要解决这个问题,建议检查JDK版本兼容性,更新JDK或参照错误报告文件提交Bug至http://bugreport.java.com/bugreport/crash.jsp。
|
21天前
|
Java
使用Java代码打印log日志
使用Java代码打印log日志
75 1
|
21天前
|
设计模式 Java 数据库
Java设计模式精讲:让代码更优雅、更可维护
【4月更文挑战第2天】**设计模式是解决软件设计问题的成熟方案,分为创建型、结构型和行为型。Java中的单例模式确保类仅有一个实例,工厂方法模式让子类决定实例化哪个类。适配器模式则协调不兼容接口间的合作。观察者模式实现了一对多依赖,状态变化时自动通知相关对象。学习和适当应用设计模式能提升代码质量和可维护性,但需避免过度使用。设计模式的掌握源于实践与不断学习。**
Java设计模式精讲:让代码更优雅、更可维护
|
22天前
|
SQL 设计模式 安全
Java单例模式几种写法以及代码案例拿来直接使用
Java单例模式几种写法以及代码案例拿来直接使用
31 0