C++使用thread类多线程编程

转载链接:https://blog.csdn.net/dcrmg/article/details/53912941

1、基本知识

1.1 thread:该头文件主要声明了 std::thread 类
1.2 mutex:该头文件主要声明了与互斥量(mutex)相关的类

2、代码示例

2.1 thread简单示例

#include <iostream>  
#include <thread>  
#include <Windows.h>  
  
using namespace std;  
  
void thread01()  
{  
    for (int i = 0; i < 5; i++)  
    {  
        cout << "Thread 01 is working !" << endl;  
        Sleep(100);  
    }  
}  
void thread02()  
{  
    for (int i = 0; i < 5; i++)  
    {  
        cout << "Thread 02 is working !" << endl;  
        Sleep(200);  
    }  
}  
  
int main()  
{  
    thread task01(thread01);  
    thread task02(thread02);  
    task01.join();  
    task02.join();  
  
    for (int i = 0; i < 5; i++)  
    {  
        cout << "Main thread is working !" << endl;  
        Sleep(200);  
    }  
    system("pause");  
}

结果输出:
在这里插入图片描述

2.2 thread detach不阻塞主线程

两个子线程并行执行,join函数会阻塞主流程,所以子线程都执行完成之后才继续执行主线程。可以使用detach将子线程从主流程中分离,独立运行,不会阻塞主线程:

#include <iostream>  
#include <thread>  
#include <Windows.h>  
  
using namespace std;  
  
void thread01()  
{  
    for (int i = 0; i < 5; i++)  
    {  
        cout << "Thread 01 is working !" << endl;  
        Sleep(100);  
    }  
}  
void thread02()  
{  
    for (int i = 0; i < 5; i++)  
    {  
        cout << "Thread 02 is working !" << endl;  
        Sleep(200);  
    }  
}  
  
int main()  
{  
    thread task01(thread01);  
    thread task02(thread02);  
    task01.detach();  
    task02.detach();  
  
    for (int i = 0; i < 5; i++)  
    {  
        cout << "Main thread is working !" << endl;  
        Sleep(200);  
    }  
    system("pause");  
}

结果输出:
在这里插入图片描述

2.3 thread带参数子线程

在绑定的时候也可以同时给带参数的线程传入参数:

#include <iostream>  
#include <thread>  
#include <Windows.h>  
  
using namespace std;  
  
//定义带参数子线程  
void thread01(int num)  
{  
    for (int i = 0; i < num; i++)  
    {  
        cout << "Thread 01 is working !" << endl;  
        Sleep(100);  
    }  
}  
void thread02(int num)  
{  
    for (int i = 0; i < num; i++)  
    {  
        cout << "Thread 02 is working !" << endl;  
        Sleep(200);  
    }  
}  
  
int main()  
{  
    thread task01(thread01, 5);  //带参数子线程  
    thread task02(thread02, 5);  
    task01.detach();  
    task02.detach();  
  
    for (int i = 0; i < 5; i++)  
    {  
        cout << "Main thread is working !" << endl;  
        Sleep(200);  
    }  
    system("pause");  
}

结果输出:
在这里插入图片描述

2.4 多线程同步mutex

多个线程同时对同一变量进行操作的时候,如果不对变量做一些保护处理,有可能导致处理结果异常:

#include <iostream>  
#include <thread>  
#include <Windows.h>  
  
using namespace std;  
  
int totalNum = 100;  
  
void thread01()  
{  
    while (totalNum > 0)  
    {  
        cout << totalNum << endl;  
        totalNum--;  
        Sleep(100);  
    }  
}  
void thread02()  
{  
    while (totalNum > 0)  
    {  
        cout << totalNum << endl;  
        totalNum--;  
        Sleep(100);  
    }  
}  
  
int main()  
{  
    thread task01(thread01);  
    thread task02(thread02);  
    task01.detach();  
    task02.detach();  
    system("pause");  
}

结果输出:
在这里插入图片描述

有两个问题,一是有很多变量被重复输出了,而有的变量没有被输出;二是正常情况下每个线程输出的数据后应该紧跟一个换行符,但这里大部分却是另一个线程的输出。

这是由于第一个线程对变量操作的过程中,第二个线程也对同一个变量进行各操作,导致第一个线程处理完后的输出有可能是线程二操作的结果。针对这种数据竞争的情况,可以使用线程互斥对象mutex保持数据同步。mutex类的使用需要包含头文件mutex。

修改后

#include <iostream>  
#include <thread>  
#include <Windows.h>  
#include <mutex>  
  
using namespace std;  
  
mutex mu;  //线程互斥对象  
  
int totalNum = 100;  
  
void thread01()  
{  
    while (totalNum > 0)  
    {  
        mu.lock(); //同步数据锁  
        cout << totalNum << endl;  
        totalNum--;  
        Sleep(100);  
        mu.unlock();  //解除锁定  
    }  
}  
void thread02()  
{  
    while (totalNum > 0)  
    {  
        mu.lock();  
        cout << totalNum << endl;  
        totalNum--;  
        Sleep(100);  
        mu.unlock();  
    }  
}  
  
int main()  
{  
    thread task01(thread01);  
    thread task02(thread02);  
    task01.detach();  
    task02.detach();  
    system("pause");  
}

结果输出:
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值