目录

第18 章探讨 C++新标准.新增的其他功能,并行编程

并行编程

第18 章探讨 C++新标准.新增的其他功能,并行编程

文章目录

  • 并行编程
  • [18.7C++11 新增的其他功能](#18.7C++11 新增的其他功能)
  • [18.7.1 并行编程](#18.7.1 并行编程)

18.7C++11 新增的其他功能

C++11增加了很多功能,本书无法全面介绍;另外,本书编写期间,其中很多功能还未得到广泛实现。

然而,有些功能有必要简要地介绍一下。

18.7.1 并行编程

当前,为提高计算机性能,增加处理器数量比提高处理器速度更容易。因此,装备了双核、四核处理器甚至多个多核处理器的计算机很常见,这让计算机能够同时执行多个线程,其中一个处理器可能处理视频下载,而另一个处理器处理电子表格。

有些操作能受益于多线程,但有些不能。考虑单向链表的搜索:程序必须从链表开头开始,沿链接依次向下搜索,直到到达链表末尾:在这种情况下,多线程的帮助不大。再来看未经排序的数组。考虑到数组的随机存取特征,可让一个线程从数组开头开始搜索,并让另一个线程从数组中间开始搜索,这将让搜

索时间减半。多线程确实带来了很多问题。如果一个线程挂起或两个线程试图同时访问同一项数据,结果将如何呢?为解决并行性问题,C+定义了一个支持线程化执行的内存模型,添加了关键字thread local,提供了相关的库支持。关键字 thread local将变量声明为静态存储,其持续性与特定线程相关;即定义这种变量的线程过期时,变量也将过期。

库支持由原子操作(atomic operation)库和线程支持库组成,其中原子操作库提供了头文件 atomic,而线程支持库提供了头文件thread、mutex、condition variable 和 future。

本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
钢铁男儿19 分钟前
Python 生成数据(使用Pygal模拟掷骰子)
开发语言·python
JuicyActiveGilbert23 分钟前
【CMake指南】第10篇:复杂项目重构与优化指南(实战)
c++·重构·教程·cmake
m0_5557629034 分钟前
动平衡仿真程序设计
c++
小L~~~34 分钟前
LFU(最不经常使用) 缓存算法实现
c++·算法·缓存
Geometry Fu36 分钟前
握手问题 第十五届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组
c语言·c++·蓝桥杯
百锦再40 分钟前
全方位对比oracle18c和oracle 19c
开发语言·网络·数据库·oracle·c#·调试·助手
君义_noip44 分钟前
信息学奥赛一本通 1831:【03NOIP提高组】神经网络 | 洛谷 P1038 [NOIP 2003 提高组] 神经网络
c++·算法·图论·信息学奥赛
苏七七学姐1 小时前
Java面试易忽略知识点
java·开发语言·面试
2402_881319301 小时前
3.17学习总结
开发语言·python·学习
宋发元1 小时前
Java 中 LinkedList 的底层数据结构及相关分析
java·开发语言·数据结构