多线程mutex locker condition简单封装_return etimedout == pthread_cond_timedwait(&cond_,(3)

img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

{
    assert(0 == holder_);//when destroy non lock
    int iret = pthread_mutex_destroy(&mutex_);
    assert(0 == iret);(void) iret;
}

/*bool isLockedByThisThread()
{
    return holder_ == CurrentThread::tid();
}

void assertLocked()
{
    assert(isLockedByThisThread() );
}*/

protected:
//internal usage
void lock()
{
pthread_mutex_lock(&mutex_);
//holder_ = CurrentThread::tid();
}

void unlock()
{
    holder_ = 0;
    pthread_mutex_unlock(&mutex_);
}

pthread_mutex_t* getPthreadMutex() /*non-const*/
{
    return &mutex_;
}

private:
pthread_mutex_t mutex_;
pid_t holder_;
};

class MutexLockGuard
{
public:
explicit MutexLockGuard(MutexLock& mutex):mutex_(mutex)
{
mutex_.lock();
}
~MutexLockGuard()
{
mutex_.unlock();
}
private:
MutexLock& mutex_;
};

//prevent misuse like:
//MutexLockGuard(mutex_); 遗漏变量名,产生一个临时变量又马上销毁了
//right method: MutexLockGuard guard(mutex_);
#define MutexLockGuard(x) error “Missing guard object name”

class Condition
{
public:
explicit Condition(MutexLock& mutex):mutex_(mutex)
{
pthread_cond_init(&pcond_,NULL);
}
~Condition()
{
pthread_cond_destroy(&pcond_);
}

void wait()
{
    pthread_cond_wait(&pcond_,mutex_.getPthreadMutex() );
}

bool waitForSeconds(int second)
{
    /* struct timespct{
     *  time_t tv_sec;
     *  long tv_nsec;
     * };
     * */
    struct timespec abstime;
    /*clock_gettime 提供纳秒的精确度
     *int clock_gettime(clockid_t clk_id, struct timespec* tp);
     *clockid_t用于指定计时时钟的类型:
     *CLOCK_REALTIME,系统实时时间,随着系统实时时间改变而改变,从UTC1970-1-1 0:0:0开始计时,中间如果系统时间更改,则对应的时间相应改变
     *CLOCK_MONOTONIC,从系统启动这一刻起开始计时,不受系统时间被用户改变的影响
     *CLOCK_PROCESS_CPUTIME_ID,本进程到当前代码系统CPU花费时间
     *CLOCK_THREAD_CPUTIME_ID,线程CPU时间
     */
    clock_gettime(CLOCK_REALTIME,&abstime);
    abstime.tv_sec += second;
    return ETIMEDOUT == pthread_cond_timedwait(&pcond_,mutex_.getPthreadMutex(),&abstime);
}

void notify()
{
    pthread_cond_signal(&pcond_);
}

void notifyAll()
{
    pthread_cond_broadcast(&pcond_);
}

private:
MutexLock& mutex_;
pthread_cond_t pcond_;
};
#endif //MULTITHREAD_H


  
 学习完陈硕大神的多线程编程,自己也依葫芦画瓢封装了个简单的多线程MutextLock、MutexLockGuard、Condition,代码如上。 

下面给出一个简单用法,用于构造一个简单的同步阻塞队列。




#include “MultiThread.h”
#include
#include <assert.h>

img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

系化!**

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

  • 8
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++11中引入了condition_variable_any类,它是一个通用的条件变量类,可以用于实现线程的同步和互斥。condition_variable_any类提供了与pthread_cond_timedwait()函数类似的功能,可以在指定的时间内等待条件满足。 要使用condition_variable_any类实现pthread_cond_timedwait(),可以按照以下步骤进行操作: 1. 创建一个condition_variable_any对象和一个mutex对象,用于线程间的同步和互斥。 2. 在等待条件满足之前,使用unique_lockmutex进行加锁。 3. 使用wait_until()函数等待条件满足或者超时。wait_until()函数接受一个时间点参数,表示等待的截止时间。 4. 在wait_until()函数返回之前,会自动释放mutex,并将线程置于等待状态。 5. 在其他线程中,当条件满足时,可以使用notify_one()或notify_all()函数来通知等待的线程。 6. 当wait_until()函数返回时,可以检查条件是否满足,如果满足则继续执行相应的操作,否则可以继续等待或者退出。 下面是一个简单的示例代码: ```cpp #include <iostream> #include <thread> #include <condition_variable> std::condition_variable_any cv; std::mutex mtx; bool condition = false; void worker() { std::this_thread::sleep_for(std::chrono::seconds(2)); std::unique_lock<std::mutex> lock(mtx); condition = true; cv.notify_one(); } int main() { std::thread t(worker); std::unique_lock<std::mutex> lock(mtx); if (cv.wait_until(lock, std::chrono::system_clock::now() + std::chrono::seconds(5), []{ return condition; })) { std::cout << "Condition is satisfied!" << std::endl; } else { std::cout << "Timeout!" << std::endl; } t.join(); return 0; } ``` 在上面的示例中,主线程等待条件满足或者超时。在worker线程中,经过2秒后将条件设置为true,并通过notify_one()函数通知主线程。主线程使用wait_until()函数等待条件满足或者超时,如果条件满足则输出"Condition is satisfied!",否则输出"Timeout!"。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值