1 进程和线程出现的原因
最初,计算机只能接受一些特定的指令,用户输入一个指令,计算机就做一个操作。效率低下,出现了 批处理操作
,但是,原来都是只有一个程序在计算机里运行 — 即 内存中始终只有一个程序的运行数据
。
进程的出现,就是为了让 内存中可以装多个程序(进程),每个进程对应着一定的内存地址空间
。并且 只能使用它自己的内存空间,各个进程间互不干扰
。并且进程保存了程序每个时刻的运行状态,这样就为进程切换提供了可能。
进程的出现解决了操作系统的并发问题。但是不能解决 实时性
。所以出现了线程。
进程让操作系统的并发性成为可能,而线程让进程的内部并发成为可能
2 进程和线程的区别
进程,又称为 轻量级线程
- 1 地址空间:同一进程的线程共享本进程的地址空间,而进程之间则是独立的地址空间
- 2 资源拥有:同一进程内的线程共享本进程的资源,但是进程之间的资源是独立的
- 3 一个进程崩溃后,在保护模式下不会对其他进程产生影响,但是
一个线程崩溃整个进程都死掉
。所以多进程要比多线程健壮 - 4 进程切换时,消耗的资源大,效率低。所以涉及到频繁的切换时,使用线程要好于进程。同样如果要求同时进行并且又要共享某些变量的并发操作,只能用线程不能用进程
- 5 执行过程:每个独立的进程程有一个程序运行的入口、顺序执行序列和程序入口。但是
线程不能独立执行,必须依存在应用程序中
,由应用程序提供多个线程执行控制 - 6
线程是处理器调度的基本单位
,但是进程不是 - 7 两者均可并发执行
3 优缺点
- 线程执行开销小,但是不利于资源的管理和保护。线程适合在SMP机器(双CPU系统)上运行
- 进程执行开销大,但是能够很好的进行资源管理和保护。进程可以跨机器前移
4 并发与并行
- 并发是指在同一时刻,只有一条命令是在处理器上执行的,但多个进程命令被快速轮换执行,使得在宏观上具有多个进程同时执行的效果
- 并行是指同一时刻,多个命令在多个处理器上同时执行