您的位置:首页 > 其它

线程的一种解决死锁的方式

2017-07-24 21:35 162 查看
一、什么是死锁?

摘自百度:

所谓死锁: 是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。 由于资源占用是互斥的,当某个进程提出申请资源后,使得有关进程在无外力协助下,永远分配不到必需的资源而无法继续运行,这就产生了一种特殊现象死锁.

关键点:1)两个以上的进程

            2)争夺共享的资源
            3)它们各自不释放手中资源,除非有外力协助

解决线程死锁的方式有很多  今天我的方式有些小白了  hhhh  我也会继续研究下

今天我的方式是  将每个执行的线程都用sleep方法设置睡眠时间  这样保证几个线程不会在同时抢夺资源

我以哲学家就餐问题为例解决

代码如下

哲学家类

package philosopher;

public class Philosopher extends Thread{

public String name;
public Chopsticks left;//左筷子
public Chopsticks right;//右筷子
public long millis;//等待时间

public Philosopher(String name,Chopsticks left,Chopsticks right,long millis){
this.name=name;
this.left=left;
this.right=right;
this.millis=millis;
}

public void run(){
try {
Thread.sleep(millis);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized(left){
System.out.println(this.name+"哲学家拿到了左手边的"+left.num+"号筷子");
synchronized(right){
System.out.println(this.name+"哲学家拿到了右手边的"+right.num+"号筷子");
System.out.println(this.name+"很开心,都抢到啦,开吃");
}
}
}
}


筷子类
package philosopher;

public class Chopsticks {

public String num;//筷子号
public Chopsticks(String num){
this.num=num;
}
}


测试类
package philosopher;

public class Test {

public static void main(String[] args) {
Chopsticks c1 = new Chopsticks("1");
Chopsticks c2 = new Chopsticks("2");
Chopsticks c3 = new Chopsticks("3");
Chopsticks c4 = new Chopsticks("4");
Philosopher p1 = new Philosopher("1号",c1,c2,0);
Philosopher p2 = new Philosopher("2号",c2,c3,300);
Philosopher p3 = new Philosopher("3号",c3,c4,0);
Philosopher p4 = new Philosopher("4号",c4,c1,300);
p1.start();
p2.start();
p3.start();
p4.start();
}
}


方法有些小白 期望大神指点

联系qq:2521340635
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐