进程(Process)
1:进程是操作系统分配资源的基本单位
2:每个进程都有自己独立的虚拟地址空间,虚拟地址空间映射真实物理地址
3:进程之间相互隔离,某一个进程的崩溃不会影响到其它进程
4:一个进程可以拥有多个线程
5:进程之间的切换要切换虚拟地址空间(开销最大)
线程(Thread)
1:线程是处理器(CPU)分配的基本单位
2:线程相当于轻量级的进程
3:在同一个进程内,多个线程可以共享进程的内存空间
4:在同一进程内,进行线程间的切换要比进程之间的切换开销要小(只用切换自身私有的资源)
5:线程是进程当中的一条执行流程(用于执行代码)
进程间的通讯方式
匿名管道:用于父子进程之间的通讯
有名管道:会生成一个文件描述符用于进程之间的通讯(任何进程之间都可以进行通讯)
消息队列:使用一个队列来存放消息,进程A将消息存入队列中,进程B只需要从队列中读取出来即可
共享内存:多个进程之间他们使用不同的虚拟内存,但是都映射到同一物理内存上
信号量:设置互斥的资源数为1,要访问这个资源只需要对该资源进行PV操作即可
信号:类似于Linux中的 kill命令,如 kill -9 pid就可以立即杀死某个进程
Socket:用于不同主机之间的通讯