C++ 之 并发编程基础

C++并发编程基础

在C++线程库中提供一个native_handle()成员函数,允许通过使用平台相关API直接操作底层实现。

为了并发地运行函数,需要使用特定的函数以及对象来管理各个线程。C++在头文件中提供了管理线程的类和函数

一个简单的Hello, Concurrent World程序:

#include <iostream>
#include <thread>  //①
void hello()  //②
{
  std::cout << "Hello Concurrent World\n";
}
int main()
{
  std::thread t(hello);  //③
  t.join();  //④
}

其中 调用方法std::thread,可见仍属于std域;同时使用join函数是为了保证t线程执行完毕后main主线程才结束。

启动线程

线程在线程对象创建时启动,即构造线程std::thread对象时便会启动。也就是说我们需要进行共享变量的设置才可以实现线程之间的相互控制。

  • 三种构建方法:
std::thread my_thread(background_task);		// 1
std::thread my_thread((background_task())); // 2
std::thread my_thread{background_task()};   // 3
  • 启动线程之后,需要明确是要等待线程结束(加入式),还是让其自主运行(分离式)
t.detach(); //(分离式),new和current线程无关
t.join();	//(加入式),阻塞current线程,执行新线程
  • 线程间的变量修改则需要使用std::ref()将数据转换为引用数据:
std::thread t(update_data_for_widget,w,std::ref(data));

数据同步的安全性实现

std::mutex mt;
void addmethod(int a)
{
    mt.lock();
    addprocessing(...);
    mt.unlock();
}
void deletemethod(int a)
{
    mt.lock();
    deleteprocessing(...);
    mt.unlock();
}

使用unique_lock或者lock_guard实现上锁。

std::mutex mt;
void addmethod(int a)
{
    std::unique_lock<std::mutex> lock(mt);
    addprocessing(...);
}
void deletemethod(int a)
{
    std::unique_lock<std::mutex> l(mt);
    deleteprocessing(...);
}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

FlameAlpha

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值