1.使用多线程的好处: 提高性能分离关注点 

2. 多线程所在头文件 <thread>

3. 使用线程方式为std::thread(functioncall),如:

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

4. thread api:

  • constructor

使用一个函数,或者是一个callable object来初始化一个thread 对象。实际就是associate一个thread对象和一个thread of execution,便能够开启一个线程了。当然你也可以声明一个thread对象而不对其associate,这个时候有些方法就不能执行。

注意:

(1)如果和thread 对象绑定的execution函数有参数,那么也是通过associate时,一同传入的。如果thread对象绑定的execution函数有返回值,那么可以通过传入一个引用,或者指针将返回值,传递出来。当然对于返回值,后面章节会有其他解决办法。

(2)一旦一个thread对象,绑定了execution函数,在其线程终止之前必须要对其进行处理。不能使其在开启这个thread的进程结束之后,还在运行。否则系统会调用std::thread::terminate()出错。解决办法有两个A。join声明由创建它的程序来回收。detach表示将其run in background,最后系统回收。

  • join

join兼有等待某个thread结束与回收其资源的作用。某个associate的对象,只能join一次,可以通过函数std::thread::joinable来判定。

  • detach  调用后线程将在后台运行run in background,该线程与这个进程内的其他线程无关了。但是若这个线程的进程结束,这个线程也会被终止。

注意: 某个associate了execution function的对象,也只能detach一次。可以用joinable来判定。return,exit都是结束进程。UNIX结束线程可以用thread_cancel

#include <thread>
#include <Windows.h> void do_something(int& i)
{
++i;
} struct func
{
int& i; func(int& i_):i(i_){} void operator()()
{
for(unsigned j=;j<;++j)
{
do_something(i);
}
}
}; void oops()
{
int some_local_state=;
func my_func(some_local_state);
std::thread my_thread(my_func);
my_thread.detach();
} int main()
{ oops(); //::Sleep(10 * 1000);
}

上述示例中,oops启动了一个线程,并调用detach()在后台运行,其实一个耗时线程,进行100万次累加操作,但是主线程main()可能已经结束退出,所以该程序可能会出现错误

  • std::move

这个函数可以显式转移线程的拥有权,线程对象不能赋值,但是可以转移。相当于,转移那个associate关系。被move的thread 对象就没有绑定的execution function了。

  • hardware_concurrency

static方法,返回这台主机的硬件并发数,即内核数量。

  • get_id()/ this_thread::get_id()

返回线程的id,返回的id类型是std::thread::id类型的。

注意:可以相互比较大小,如果两个大小相同,他们就是相同的thread。

必须要associate execution function的thread object才有有意义的数字thread id。返回没有associate的,会显示没有绑定,但不会终止程序。

5. 线程的启动

在定义thread创建的时候即启动线程

6. 线程的委托对象

函数/ Callable对象实例(即带重载operator()的对象class或struct)

如下面代码中的CallableStruct结构体即为Callable对象,

struct CallableStruct
{
int& i; func(int& i_):i(i_){} void operator()()
{
for(unsigned j=;j<;++j)
{
std::cout<<j<<std::endl;
}
}
}; int some_local_state=;
CallableStruct my_CallableStruct(some_local_state);
std::thread my_thread(my_CallableStruct);
my_thread.detach();

使用Callable对象实例初始化线程时推荐使用以下方式:

std::thread my_thread((CallableStruct()));  // 多加一层括号将对象的实例化给括起来
std::thread my_thread{CallableStruct()}; //C++ 11 初始化语法
std::thread my_thread(CallableStruct());  // 错误,意思变成了指向一个无参数,返回值为CallableStruct的函数指针

C++ 并发编程 01 线程api的更多相关文章

  1. JUC 并发编程--01,线程,进程,经典卖票案例, juc的写法

    进程: 就是一个程序, 里面包含多个线程, 比如一个QQ程序 线程: 进程中最小的调度单元, 比如 QQ中的自动保存功能 并发: 多个线程操作同一资源, 抢夺一个cpu的执行片段, 快速交替 并行: ...

  2. Java并发编程:线程池的使用

    Java并发编程:线程池的使用 在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了, ...

  3. 并发编程 01—— ThreadLocal

    Java并发编程实践 目录 并发编程 01—— ThreadLocal 并发编程 02—— ConcurrentHashMap 并发编程 03—— 阻塞队列和生产者-消费者模式 并发编程 04—— 闭 ...

  4. 并发编程 13—— 线程池的使用 之 配置ThreadPoolExecutor 和 饱和策略

    Java并发编程实践 目录 并发编程 01—— ThreadLocal 并发编程 02—— ConcurrentHashMap 并发编程 03—— 阻塞队列和生产者-消费者模式 并发编程 04—— 闭 ...

  5. Java并发编程:线程池的使用(转)

    Java并发编程:线程池的使用 在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了, ...

  6. Java并发编程:线程池的使用(转载)

    转载自:https://www.cnblogs.com/dolphin0520/p/3932921.html Java并发编程:线程池的使用 在前面的文章中,我们使用线程的时候就去创建一个线程,这样实 ...

  7. Java并发编程:线程池的使用(转载)

    文章出处:http://www.cnblogs.com/dolphin0520/p/3932921.html Java并发编程:线程池的使用 在前面的文章中,我们使用线程的时候就去创建一个线程,这样实 ...

  8. [转]Java并发编程:线程池的使用

    Java并发编程:线程池的使用 在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了, ...

  9. 【转】Java并发编程:线程池的使用

    Java并发编程:线程池的使用 在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了, ...

随机推荐

  1. 在MyEclise中使用自己安装的tomcat

    ·将Tomcat配置到MyEclipse中 1.在MyEclipse中打开Window子选项Preferences: 2.在Preferences面板中,点击左边选项中的MyEclipse,找到Ser ...

  2. python fromkeys() 创建字典

    # d = dict.fromkeys("张无忌","赵敏") #创建字典 # print(d)#{'张': '赵敏', '无': '赵敏', '忌': '赵敏 ...

  3. Win7SDK

    1.ISO下载地址: http://www.microsoft.com/en-us/download/details.aspx?id=8442 2.可供下载的 版本有3个,网上搜到的解释: GRMSD ...

  4. CF 483B. Friends and Presents 数学 (二分) 难度:1

    B. Friends and Presents time limit per test 1 second memory limit per test 256 megabytes input stand ...

  5. java应用简单递归

    毕业后就怎么学过算法,还在上学的时候学过数据结构,现在基本上都还给老师了,可惜老师学费没有还给我... 情景: 类似于给定一个数字,算他由多少个数字组成,比如:36 现在有10.5.1 ,那么最佳帅3 ...

  6. 记录JAVAWEB部署到JBOSS中遇到的问题

    服务器环境 jdk1.8.0_212 + jboss-eap-6.4  系统是 Service 2008 R2 数据服务器 oracle12c  系统是 Service 2008 R2 首先安装的or ...

  7. 2018.12.25 SOW

    1. Understanding Customer Requirements 11.1. Project Overview 21.2. System Requirements 21.3. Indust ...

  8. 利用python完成多个url状态码的检测

    import re import requests import json from threading import Thread,Lock from concurrent.futures impo ...

  9. Linux运维学习笔记-网络安全等级保护

    网络安全等级保护简介与作用: 验证信息系统是否满足相应安全保护等级的一个过程. 对不同信息系统分等级进行保护.

  10. HDU 3973 AC's String 字符串哈希

    HDU 3973 通过哈希函数将一个字符串转化为一个整数,通过特定的方式可以使得这个哈希值几乎没有冲突(这就是关键之处,几乎没有视为没有= =!, 其实也可以考虑实现哈希冲突时的处理,只是这道题没必要 ...