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

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

并发

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

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

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

可执行程序

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

进程

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

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

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

线程

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

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

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

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

多线程(并发)

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

二:并发的实现方法

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

实现并发的手段:

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

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

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

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

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

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

相关推荐
小李子呢02112 小时前
前端八股浏览器网络(2)---cookie,localStorage,sessionStorage
前端·网络
Polar__Star2 小时前
HTML函数在多GPU系统中如何调用_显卡切换机制说明【汇总】
jvm·数据库·python
wiliam_luky2 小时前
视频编解码
网络·视频编解码
2301_813599552 小时前
mysql为什么不要在索引列上做运算_mysql函数索引使用场景
jvm·数据库·python
瀚高PG实验室2 小时前
因磁盘IO性能低导致程序An I/O error 报错
java·jvm·数据库·瀚高数据库
qq_342295822 小时前
如何监控集群 interconnect_ping与traceroute验证心跳通畅
jvm·数据库·python
qq_342295822 小时前
Go语言错误处理如何做_Go语言error错误处理教程【实用】
jvm·数据库·python
qq_334563552 小时前
如何在phpMyAdmin中执行多条SQL语句_分号分隔与批量执行解析
jvm·数据库·python
2401_897190552 小时前
Golang如何做Clean Architecture_Golang整洁架构教程【详解】
jvm·数据库·python