C++并发基本概念及实现、进程、基本概念

一.并发,进程,线程的基本概念和综述

并发

两个或者更多的任务(独立的活动)同时发生(进行):一个程序同时执行多个独立的任务。

以往计算机,单核cpu(中央处理器):某一个时刻只能执行一个任务:由操作系统调度,每秒钟进行多次所谓的"任务切换"。这是并发的假象(不是真正的并发);这种切换(上下文切换)是要有时间开销的。

使用并发的原因:同时可以执行多个任务,提高性能。

可执行程序

磁盘上的一个文件,例如windows下.exe,linux,1s-la,rwxrwxrwx(x执行权限);

进程

windows下,双击一个可执行程序来运行。linux下./文件名//进程

就是一个可执行程序运行起来了,就叫创建了一个进程;

进程:运行起来了的可执行程序。

线程

线程是代码的执行道路(从上到下执行完毕)。

每个进程都有一个主线程,这个主线程是唯一的,产生了一个进程后这个主线程就随着这个进程启动起来了。

运行一个程序实际上是进程的主线程来执行main函数的代码。主线程和进程的寿命完全一致,主线程执行到return结束后,进程也随之结束。

出主线程外还可以通过代码创建其他线程,其他线程走的是别的道路甚至去不同的地方。每创建一个新线程就可以在同一个时刻多干一个不同的事(多走一条代码的不同路径)。

多线程(并发)

线程不是越多越好,每个线程都需要一个独立的堆栈空间,堆栈之间的切换要保存很多中间状态。切换会耗费本该属于程序运行的时间。

二:并发的实现方法

两个或者更多的任务(独立的活动)同时发生(进行)

实现并发的手段:

  • 通过多个进程实现并发。
  • 在单独的进程中,创建多个线程来实现并发;自己写代码来创建除了主线程之外的其他线程;
多进程并发

进程之间通信(同一个电脑上:管道,文件,消息对列,共享内存);

不同电脑上:socket通信技术;

多线程并发:单个进程中,创建了多个线程。(建议)

每个线程都有自己独立的运行路径,但是一个进程中的所有线程共享地址空间(共享内存)

全局变量,指针,引用都可以在线程之间传递,所以:使用多线程开销远远小于多进程。

相关推荐
iuvtsrt几秒前
SQL如何优化子查询的性能_改写为JOIN关联查询与消除嵌套
jvm·数据库·python
Amnesia0_01 分钟前
网络基础与协议
网络
2403_883261092 分钟前
C#怎么使用并发集合 C#ConcurrentDictionary和ConcurrentQueue线程安全集合怎么用【进阶】
jvm·数据库·python
m0_470857642 分钟前
如何加固SQL系统架构_采用读写分离降低攻击影响
jvm·数据库·python
2401_884454153 分钟前
Golang如何写博客系统后端_Golang博客系统教程【技巧】
jvm·数据库·python
2301_779622414 分钟前
JavaScript中利用Range对象实现复杂的文本选择操作
jvm·数据库·python
m0_741481784 分钟前
Go语言怎么做接口签名_Go语言API签名验证教程【精通】
jvm·数据库·python
2401_884454155 分钟前
CSS实现浮动图标与文本居中对齐_配合浮动与flex
jvm·数据库·python
woxihuan1234566 分钟前
SQL统计分组内的所有数据唯一值_使用DISTINCT汇总
jvm·数据库·python
m0_631529827 分钟前
CSS如何利用-disabled伪类禁用交互元素_通过灰度效果提升界面逻辑清晰度
jvm·数据库·python