muduo库 Thread

本文介绍了一个C++非复制able类Thread,使用std::function和线程库管理异步任务。通过信号量控制线程创建顺序,展示了如何使用ThreadFunc类型定义线程操作,以及如何确保线程安全地启动、加入和管理线程实例。

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

#pragma once

#include "noncopyable.h"

#include <functional>
#include <thread>
#include <memory>
#include <unistd.h>
#include <string>
#include <atomic>

class Thread : noncopyable
{
public:
    using ThreadFunc = std::function<void()>;

    explicit Thread(ThreadFunc, const std::string &name = std::string());
    ~Thread();

    void start();
    void join();

    bool started() const { return started_; }
    pid_t tid() const { return tid_; }
    const std::string& name() const { return name_; }

    static int numCreated() { return numCreated_; }
private:
    void setDefaultName();

    bool started_;
    bool joined_;
    std::shared_ptr<std::thread> thread_;
    pid_t tid_;
    ThreadFunc func_;
    std::string name_;
    static std::atomic_int numCreated_;
};
#include"Thread.h"

#include"CurrentThread.h"
#include<semaphore.h>

std::atomic_int Thread::numCreated_ = {0};

Thread::Thread(ThreadFunc func,const std::string &name)
    :started_(false)
    ,joined_(false)
    ,tid_(0)
    ,func_(std::move(func))
    ,name_(name)
{
    setDefaultName();
}

Thread::~Thread()
{
    //线程已经开启,并且不在工作,才可以析构它
    if(started_ && !joined_)
    {
        thread_->detach();//thread类提供了设置分类线程的方法
    }
}

//一个Thread对象,记录的是一个新线程的详细信息
void Thread::start()
{
    started_=true;

    /*
    *   这里用到信号量的考量是,必须等待线程创建以后,才能跳出start函数,因此用到信号量
    */
    //信号量
    sem_t sem;
    sem_init(&sem,false,0);

    //开启线程
    thread_=std::shared_ptr<std::thread>(new std::thread([&](){
        //获取线程tid值
        tid_=CurrentThread::tid();

        sem_post(&sem);

        //开启一个新线程,专门执行该函数
        func_();

    }));

    //这里必须等待获取上面新创建的线程的tid值
    sem_wait(&sem);
}

void Thread::join()
{
    joined_=true;
    thread_->join();
}

void Thread::setDefaultName()
{
    int num=++numCreated_;
    if(name_.empty())
    {
        char buf[32]={0};
        snprintf(buf,sizeof buf,"Thread %d",num);
        name_=buf;
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值