#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 带超时的递归互斥量