多线程

 

#include <thread>//多线程的头文件

第一步:写一个返回值为void的函数作为线程的主体,例如:

void thread01()//作为类似Main函数的作用;
{
}

第二步:在Main函数里创建一个多线程对象,函数名作为参数传进去,例:

thread task01(thread01);

这样多线程就创建成功了;这时task01和Main函数是同级别的,一起执行;

task01.join()函数会阻塞主流程-意思该线程优先于主线程执行,只有该线程执行完,主线程才会执行

task01.detac()函数与joio函数相反,它使子线程和Main函数作为同级执行;默认状态

(目前了解到的多线程输出同时,不会是乱码,是根据输出时间区别并列先后输出)

带参数的子线程实现和普通的实现一样,区别如下例:

 

定义:void thread01(int num)

实现:thread task01(thread01, 5);

数据竞争:当多个线程在操作或修改同一个数据时,可能会出现被别的线程修改后的数据,所以给数据加个防护锁,即,有一个线程访问它的时候,别的线程禁止访问该数据

 

#include <mutex>//包含头文件

mutex mu;创建锁对象;

mu.lock();加锁

mu.unlock();开锁

 

基本操作:线程ID:task01.get_id();

                  CPU核数:thread::hardware_concurrency()

                  主函数阻塞等待线程结束 t1.join();

                   主函数和线程函数分离执行,线程变为后台线程 //t1.detach();

                  lock_guard<mutex>s(mu)管理锁,释放锁空间(待定)

互斥量
分为4种 
std::mutex 独占的互斥量,不能递归使用 
std::timed_mutex 带超时的独占的互斥量,不能递归使用 
std::recursive_mutex 递归互斥量,不带超时功能 
std::recursive_timed_mutex 带超时的递归互斥量
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值