【读书笔记】第1章 你好,C++并发世界

2024-09-01 12:48

本文主要是介绍【读书笔记】第1章 你好,C++并发世界,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.1 什么是并发(concurrency)

并发是指两个或更多独立的活动同时发生。

1.1.1 计算机系统中的并发

大多数计算机只有一个处理器,具有单个处理单元(processing unit)或核心(core),如今还有很多这样的台式机。通过“这个任务做一会,再切换到别的任务,再做一会儿”的方式,让任务看起来是并行执行的。这种方式称为“任务切换(task switching)”。如今,我们仍然将这样的系统称为并发(concurrency):因为任务切换得太快,以至于无法感觉到任务在何时会被暂时挂起,而切换到另一个任务。
基于单芯多核处理器(多核处理器)的台式机,这些机器都能够真正的并行多个任务。我们称其为“硬件并发(hardware concurrency)”。
在这里插入图片描述
并发的两种方式:双核机器的真正并行 Vs. 单核机器的任务切换

即便是具有真正硬件并发的系统,也很容易拥有比硬件“可并行最大任务数”还要多的任务需要执行,所以任务切换在这些情况下仍然适用。
在这里插入图片描述四个任务在两个核心之间的切换

1.1.2并发的途径

  1. 多进程并发
    将应用程序分为多个、独立的、单线程进程,这些独立的进程可以通过所有常规的进程间通信渠道互相传递信息(信号、套接字、文件、管道等)。
    在这里插入图片描述

  2. 多线程并发
    线程很像轻量级的进程:每个线程相互独立运行,且线程可以在不同的指令序列中运行。但是,进程中的所有线程都共享地址空间,并且所有线程访问到大部分数据———全局变量仍然是全局的,指针、对象的引用或数据可以在线程之间传递。
    在这里插入图片描述

1.2为什么使用并发

主要原因有两个:关注点分离和性能。

1.2.1为了划分关注点而使用并发

在编写软件时,划分关注点总是个好主意。通过将相关的代码放在一起并将无关的代码分开,这种方法可以使你的程序更容易理解和测试,从而减少出错的可能。可以使用并发来分隔不同的功能区域,即使在这些不同功能区域的操作需要在同一时刻发生。
例如DVD的从光盘读取数据播放以及响应用户消息。

1.2.2为了性能而使用并发

第一,将一个单个任务分成几部分,且各自并行运行,从而降低总运行时间。这就是任务并行(task parallelism)
在过程方面——一个线程执行算法的一部分,而另一个线程执行算法的另一个部分——或是在数据方面——每个线程在不同的数据部分上执行相同的操作(第二种方式)。后一种方法被称为数据并行(data parallelism)

1.2.3什么时候不使用并发

不使用并发的唯一原因就是在收益比不上成本的时候。

1.3 在C++中使用并发和多线程

1.3.1 C++多线程历程

1988C++标准版不承认多线程的存在,并且各种语言要素的操作效果都以顺序抽象机的形式编写。

1.3.2 新标准中的并发支持

C++11有了全新的线程感知内存模型,C++标准库也被扩展了,包含了用于管理线程、保护共享数据、线程间同步操作、以及降低原子操作。
Boost线程库被用作新类型库所基于的主要模型,很多类与Boost中对应者共享命名和结构。

1.3.3 C++线程库的效率

1.3.4 平台相关的工具

为了能方便地访问那些工具而又不用放弃使用标准C++线程库带来的好处,C++线程库中的类型可以提供一个native_handle()成员函数,允许通过使用平台相关API直接操作底层实现。

1.4 开始入门

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

在此并发程序中,主要增添了如下内容:
1、#include < thread>头文件,用于管理线程和类的在< thread>中声明,保护共享数据的函数和类在其它头文件中声明。
2、写信息的代码被移到了一个独立的函数中,每个线程必须具有一个初始函数(initial function),新线程执行在这里开始。对于应用程序,初始线程是main(),对于std::thread对象拥有新函数hello()作为其初始函数。
3、该程序启动了一个全新的线程来实现标准输出,将线程一分为二,初始线程始于main(), 而新线程始于hello()。
4、启动新线程(hello() )后,初始线程继续执行,如果不等待新线程结束,讲自顾自的运行到main()结束,从而结束进程-有可能发生在新线程有机会运行之前。这也就是调用**join()**的原因。

1.5 小结

在这一章节中说了并发以及多线程的含义。并解释了一个简单的多线程示例。

这篇关于【读书笔记】第1章 你好,C++并发世界的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1126986

相关文章

C++中实现调试日志输出

《C++中实现调试日志输出》在C++编程中,调试日志对于定位问题和优化代码至关重要,本文将介绍几种常用的调试日志输出方法,并教你如何在日志中添加时间戳,希望对大家有所帮助... 目录1. 使用 #ifdef _DEBUG 宏2. 加入时间戳:精确到毫秒3.Windows 和 MFC 中的调试日志方法MFC

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

揭秘世界上那些同时横跨两大洲的国家

我们在《世界人口过亿的一级行政区分布》盘点全球是那些人口过亿的一级行政区。 现在我们介绍五个横跨两州的国家,并整理七大洲和这些国家的KML矢量数据分析分享给大家,如果你需要这些数据,请在文末查看领取方式。 世界上横跨两大洲的国家 地球被分为七个大洲分别是亚洲、欧洲、北美洲、南美洲、非洲、大洋洲和南极洲。 七大洲示意图 其中,南极洲是无人居住的大陆,而其他六个大洲则孕育了众多国家和

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名