当前位置:   article > 正文

多线程相关的三组概念

多线程相关的三组概念

 

程序和进程

  1. 程序(program):一个固定的运行逻辑和数据的集合,是一个静态的状态,一般存储在硬盘
  2. 进程(process):一个正在运行的程序,是一个程序的一次运行,是一个动态的概念,一般存储在内存中。

  例如:ctrl + shift + esc,打开任务管理器可以看到所有进程

进程和线程

  1. 进程(process):一个正在执行的程序,有自己独立的资源分配,是一个独立的资源分配单位。 Cpu、内存
  2. 线程(thread):一条独立的执行路径。多线程,在执行某个程序的时候,该程序可以有多个子任务,每个线程都可以独立的完成其中一个任务。在各个子任务之间,没有什么依赖关系,可以单独执行。
  3. 进程和线程的关系:

  进程是用于分配资源的单位

一个进程中,可以有多条线程;但是一个进程中,至少有一条线程

 线程不会独立的分配资源,一个进程中的所有线程,共享同一个进程中的资源

并行和并发

  1. 并行(parallel):多个任务(进程、线程)同时运行。在某个确定的时刻,有多个任务在执行

  条件:有多个cpu,多核编程

  1. 并发(concurrent):多个任务(进程、线程)同时发起不能同时执行的(只有一个cpu),只能是同时要求执行。就只能在某个时间片内,将多个任务都有过执行。一个cpu在不同的任务之间,来回切换,只不过每个任务耗费的时间比较短,cpu的切换速度比较快,所以可以让用户感觉就像多个任务在同时执行。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/197677
推荐阅读
相关标签
  

闽ICP备14008679号