程序和进程
- 程序(program):一个固定的运行逻辑和数据的集合,是一个静态的状态,一般存储在硬盘中
- 进程(process):一个正在运行的程序,是一个程序的一次运行,是一个动态的概念,一般存储在内存中。
例如:ctrl + shift + esc,打开任务管理器可以看到所有进程
进程和线程
- 进程(process):一个正在执行的程序,有自己独立的资源分配,是一个独立的资源分配单位。 Cpu、内存
- 线程(thread):一条独立的执行路径。多线程,在执行某个程序的时候,该程序可以有多个子任务,每个线程都可以独立的完成其中一个任务。在各个子任务之间,没有什么依赖关系,可以单独执行。
- 进程和线程的关系:
进程是用于分配资源的单位
一个进程中,可以有多条线程;但是一个进程中,至少有一条线程
线程不会独立的分配资源,一个进程中的所有线程,共享同一个进程中的资源
并行和并发
- 并行(parallel):多个任务(进程、线程)同时运行。在某个确定的时刻,有多个任务在执行
条件:有多个cpu,多核编程
- 并发(concurrent):多个任务(进程、线程)同时发起。不能同时执行的(只有一个cpu),只能是同时要求执行。就只能在某个时间片内,将多个任务都有过执行。一个cpu在不同的任务之间,来回切换,只不过每个任务耗费的时间比较短,cpu的切换速度比较快,所以可以让用户感觉就像多个任务在同时执行。