死锁的实例

死锁的代码:

package com.et.java.thread;


public class DeadLockTest extends Thread{
static Object obj1=new Object();
static Object obj2=new Object();
int flag;
public DeadLockTest(){};
public DeadLockTest(String name){
super(name);
}
@Override
public void run() {
if(flag==1){
synchronized (obj1) {
System.out.println("拿到了红苹果,还需要拿到青苹果");
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (obj2) {
System.out.println("拿到了青苹果");
}
}
}else if(flag==2){
synchronized (obj2) {
System.out.println("拿到了青苹果,还需要拿到红苹果");
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (obj1) {
System.out.println("拿到了红苹果");
}
}
}
}
public static void main(String[] args) {
DeadLockTest dlt1=new DeadLockTest("dlt1");
dlt1.flag=1;
DeadLockTest dlt2=new DeadLockTest("dlt2");
dlt2.flag=2;
dlt1.start();
dlt2.start();
}


}

### Linux 环境下线程死锁实例 在Linux环境中,当两个或更多线程互相等待对方持有的资源而不释放自己拥有的资源时就会发生死锁。下面展示了一个简单的C语言程序,在该程序中有两个线程分别尝试获得两把不同的锁`mutex_a`和`mutex_b`,如果这两个线程按照相反顺序获取这两把锁,则可能会陷入死锁状态。 ```c #include <pthread.h> #include <stdio.h> #include <unistd.h> // 定义两个互斥量作为锁对象 pthread_mutex_t mutex_a = PTHREAD_MUTEX_INITIALIZER; pthread_mutex_t mutex_b = PTHREAD_MUTEX_INITIALIZER; void* thread_func_1(void *arg){ printf("Thread 1 running\n"); pthread_mutex_lock(&mutex_a); printf("Thread 1 has locked obj1\n"); sleep(1); // 模拟工作延迟 pthread_mutex_lock(&mutex_b); printf("Thread 1 has locked obj2\n"); // 执行一些操作... pthread_mutex_unlock(&mutex_b); pthread_mutex_unlock(&mutex_a); return NULL; } void* thread_func_2(void *arg){ printf("Thread 2 running\n"); pthread_mutex_lock(&mutex_b); printf("Thread 2 has locked obj2\n"); sleep(1); // 模拟工作延迟 pthread_mutex_lock(&mutex_a); printf("Thread 2 has locked obj1\n"); // 执行一些操作... pthread_mutex_unlock(&mutex_a); pthread_mutex_unlock(&mutex_b); return NULL; } int main(){ pthread_t tid1, tid2; pthread_create(&tid1, NULL, thread_func_1, NULL); pthread_create(&tid2, NULL, thread_func_2, NULL); pthread_join(tid1, NULL); pthread_join(tid2, NULL); return 0; } ``` 上述代码展示了如何在线程之间形成潜在的死锁情况[^1]。为了防止这种情况的发生,可以考虑采用一致性的加锁策略,比如总是先锁定较小编号的对象再锁定较大编号的对象;也可以利用非阻塞式的锁机制如`pthread_mutex_trylock()`来检测是否能够成功取得所需的所有锁而不会造成死锁风险[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值