程序VS进程(Process)VS线程(Thread)
程序是指令的集合,静态文本
进程是程序在一个数据集上运行的过程,进行资源分配和调度的单元
线程是进程中的实体,被系统独立调度和执行的基本单元,可共享资源
进程间通信方法
管道,信号量,消息队列,套接字
管道( pipe ):管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程间使用。进程的亲缘关系通常是指父子进程关系。
有名管道 (named pipe) : 有名管道也是半双工的通信方式,但是它允许无亲缘关系进程间的通信。
信号量( semophore ) : 信号量是一个计数器,可以用来控制多个进程对共享资源的访问。它常作为一种锁机制,防止某进程正在访问共享资源时,其他进程也访问该资源。因此,主要作为进程间以及同一进程内不同线程之间的同步手段。
消息队列( message queue ) : 消息队列是由消息的链表,存放在内核中并由消息队列标识符标识。消息队列克服了信号传递信息少、管道只能承载无格式字节流以及缓冲区大
套接字( socket ) : 套解口也是一种进程间通信机制,与其他通信机制不同的是。它可用于不同进程间的进程通信,指定端口号即可。
线程同步与互斥概念
线程同步:
使并发执行的各线程之间能够有效的共享资源。
互斥VS同步:
AB竞争资源的相互制约叫做互斥;A做完提供给B,B才能继续做,有先后顺序,叫做同步。互斥是一种特殊的同步。
同步VS异步:
同步必须有先后,异步无所谓先后。
多线程同步互斥的常见方法:
事件event、互斥量,互斥锁mutex、信号量PV。
事件:事件能够通知一个线程的操作已经完成。
互斥量:所有权
信号量:信号量可以计算资源当前剩余量,是一个计数器。
临界资源和临界区
临界资源:一段时间内只允许一个线程访问的资源就称为临界资源或独占资源
临界区:访问临界资源的代码称为临界区
进程间同步问题
参考