进程间通讯有很多种实现方式,信号量也算是一种通讯方式,它是对进程间共享资源的一种管理。为了防止出现多个进程访问一个共享资源时引发的一系列问题,引出了信号量,以此来管理进程对共享资源的使用权限。
临界资源:同一时刻,只能被一个进程访问的资源。
临界区:访问临界资源的代码区域。
原子操作:任何情况下都不能被打断的操作。
内核对象:用于对进程间通讯时,多个进程能够访问同一资源的记录
信号量的作用:进程间同步机制,信号量相对于记录资源同时能被多少进程访问
信号量多用于进程间的同步与互斥,简单的说下同步和互斥
同步:处理竞争就是同步,安排进程执行的先后顺序就是同步,每个进程都有先后执行的顺序。
互斥:互斥访问不可共享的临界资源,同时会引发两个新的控制问题。
竞争:当并发进程竞争使用同一个资源的时候,我们就要称为竞争。
信号量的操作:
创建或获取: set_get();(获取信号量,如果是第一次,则创建信号量并初始化)
Int semget((ket)ket, int nsems, int flag);实现以上函数所用函数
减一操作: set_p();
加一操作: set_v();
int semop(int semid, struct sembuf *buff, int lenth);
用户改变信号量的值,也就是使用资源还是释放资源的权限函数
删除: sem_del();
int semctl(int semid, int pos, int cmd, /*union semun un*/);
控制信号量的信息函数
信号量实现原理:(进程间同步)
自己理解与感悟:
信号量的工作机制,其实就是相当于一个计数器,来记录共享资源的进程访问个数,每当有进程申请访问,就使用信号量,通过P操作进行减一操作,当计数器减到值为0时,说明当前已有进程在访问中,没有可用的共享资源了,其他进程想要访问的话必须等待正在访问进程执行完退出,当正在访问中的进程已经使用完后,就会执行v操作来对信号量进行加一操作。这个时候信号量这个计数器已不再为0,其他进程就可以访问了。
总之,信号量就是对进程访问共享资源的一种管理模式。