C++封装POSIX 线程库(一)互斥锁的封装

本文介绍了如何封装POSIX线程库中的互斥锁,探讨了互斥锁的作用和基本操作,并展示了如何利用C++实现互斥锁的初始化、加锁、释放以及避免赋值和拷贝的封装技巧。通过RAII技术确保资源的正确管理,简化多线程编程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C++封装POSIX 线程库(一)互斥锁的封装

在知乎上有人吐槽说C++11多线程库做的太复杂,建议自己封装一蛤,只要一个下午就搞定了。当然我没有陈硕老师那么大本事,花了几天时间,学习了一下把POSIX Pthread进行简单的封装。


1.互斥锁简介

互斥锁主要用于互斥,互斥是一种竞争关系,用来保护临界资源一次只被一个线程访问。
POSIX Pthread提供下面函数用来操作互斥锁。

int pthread_mutex_init(pthread_mutex_t  *mutex,  const  pthread_mutexattr_t *mutexattr);
int pthread_mutex_lock(pthread_mutex_t *mutex);
int pthread_mutex_trylock(pthread_mutex_t *mutex);
int pthread_mutex_unlock(pthread_mutex_t *mutex);
int pthread_mutex_destroy(pthread_mutex_t *mutex);
//返回:
//pthread_mutex_init总是返回0
//其他mutex函数返回0表示成功,非0的错误码表示失败

由于pthread系列函数返回成功的时候都是0,因此,我们可以写一个宏作为一个轻量级的检查手段,来判断处理错误。

#define CHECK(exp) \
    if(!exp) \
    { \
        
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值