zoukankan      html  css  js  c++  java
  • 【好记性不如烂笔头】死锁之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的锁,来吧~互相伤害,哈哈。

    黑夜给了我黑色的眼睛,我却用它寻找光明
  • 相关阅读:
    SFML从入门到放弃(3) 视角和碰撞检测
    SFML从入门到放弃(2) 图像和音频
    SFML从入门到放弃(1) 窗口和交互
    SFML从入门到放弃(0) 配置环境
    NOI2017 酱油记
    【bzoj4889】: [Tjoi2017]不勤劳的图书管理员 分块-BIT
    【bzoj4888】: [Tjoi2017]异或和 BIT-乱搞
    【bzoj4887】:[Tjoi2017]可乐 矩阵乘法,快速幂
    THUSC2017酱油记
    CTSC2017酱油记
  • 原文地址:https://www.cnblogs.com/wyongbo/p/DeadLock.html
Copyright © 2011-2022 走看看