【编程练习】多线程编写一个存在死锁的代码

本文通过一个简单的C++代码示例,解释了死锁的概念,展示了当两个线程互相等待对方释放资源时产生的死锁情况。分析了导致死锁的原因,即"请求和保持"条件,并提出了解决死锁的一种方法,即避免在输出时使用endl,以保持同步。同时,讨论了C++11中thread类在多线程编程中的应用。
摘要由CSDN通过智能技术生成

昨天的面试被这个问题挂了,平时忽略了这方面的学习,这里补一下这里的知识。
多线程的基础这篇里有讲:https://blog.csdn.net/weixin_44611644/article/details/95453398
或者参考c++多线程|菜鸟教程 直接搜得到。

下面给出我的c++简单代码。变量x1,x2代表2个资源,值为1时相当于可以访问,值为0时代表被某一线程锁住,其他线程不能访问。

#include <iostream>
#include <pthread.h>//线程头文件 
using namespace std;
int x1=1;//1表示可以访问 
int x2=1;

// 线程的运行函数
void* fun1(void* args)
{
	bool res=true;//记录线程是否访问成功 
    cout << "线程1创建成功" << endl;
    if(x1==1)
	{	
		x1=0;//访问x1,给x1加锁
		cout << "线程1访问变量x1,给x1加锁" << endl;
	}
	else
	{
		res=false;
		cout<<"线程1访问变量x1失败,x1被其他线程加锁"<<endl;
	}
	if(x2==1)
	{	
		x2=0;//访问x2,给x2加锁 
		cout << "线程1访问变量x2,给x2加锁" << endl;
	}
	else
	{
		res=false;
		cout<<"线程1访问变量x2失败,x2被其他线程加锁"<<endl;
	}
	if(res)
	{
		x1=
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值