操作系统基础
并行和并发
并行:在同一个时刻,有多个指令在单个CPU同时执行
并发:在同一个时刻,有多个指令在单个CPU交替执行
进程和线程
进程:正在运行的软件(就是操作系统中正在运行的一个应用程序)
独立性:进程是一个能独立运行的基本单位,同时也是系统分配资源和调度的独立单位
动态性:进程的实质是程序的一次执行过程,进程是动态产生的,动态消亡的
并发性:任何进程都可以同其他进程一起并发执行(CPU在多个进程之间进行一个动态的切换)
线程:是进程中的单个顺序控制流,是一条执行路径(就是应用程序中做的事情)
单线程:一个线程如果只有一条执行路径,则称为单线程程序 多线程:一个进程如果有多条执行路径,则成为多线程程序
进程和线程
进程和线程的区别
进程是资源分配的基本单位,线程是CPU调度的最小单位
一个线程只能有一个进程,一个进程可以有多个线程
进程间不会相互影响,但是一个线程如果崩溃,会导致进程与其一起崩溃
进程具有的特征:
动态性:进程是程序的一次执行过程,是临时的,有生命期的,是动态产生的,动态消亡的
并发性:任何进程都可以同其他进行一起并发执行
独立性:进程是系统进行资源分配和调度的一个独立单位
结构性:是由程序,数据和进程块三部分组成
进程间的通信方式:
1.无名管道( pipe ): 管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程间使用。进程的亲缘关系通常是指父子进程关系。
2.高级管道(popen): 将另一个程序当做一个新的进程在当前程序进程中启动&#