(计算机操作系统)wait操作和signal操作什么意思?
wait操作:
sem_wait是一个函数,也是一个原子操作,它的作用是从信号量的值减去一个“1”,但它永远会先等待该信号量为一个非零值才开始做减法。也就是说,如果你对一个值为2的信号量调用sem_wait(),线程将会继续执行,将信号量的值将减到1。
如果对一个值为0的信号量调用sem_wait(),这个函数就会原地等待直到有其它线程增加了这个值使它不再是0为止。如果有两个线程都在sem_wait()中等待同一个信号量变成非零值。
那么当它被第三个线程增加 一个“1”时,等待线程中只有一个能够对信号量做减法并继续执行,另一个还将处于等待状态。sem_trywait(sem_t *sem)是函数sem_wait的非阻塞版,它直接将信号量sem减1,同时返回错误代码。
signal操作:
sig是传递给signal的唯一参数。执行了signal()调用后,进程只要接收到类型为sig的信号,不管其正在执行程序的哪一部分,就立即执行func()函数。当func()函数执行结束后,控制权返回进程被中断的那一点继续执行。
signal()会依参数signum 指定的信号编号来设置该信号的处理函数。当指定的信号到达时就会跳转到参数handler指定的函数执行。
当一个信号的信号处理函数执行时,如果进程又接收到了该信号,该信号会自动被储存而不会中断信号处理函数的执行,直到信号处理函数执行完毕再重新调用相应的处理函数。但是如果在信号处理函数执行时进程收到了其它类型的信号,该函数的执行就会被中断。
扩展资料:
signal操作的注意点:
1、不要使用低级的或者STDIO.H的IO函数
2、不要使用对操作
3、不要进行系统调用
4、不是浮点信号的时候不要用longjmp
5、signal函数是由ISO C定义的。因为ISO C不涉及多进程,进程组以及终端I/O等,所以他对信号的定义非常含糊,以至于对UNIX系统而言几乎毫无用处。
参考资料来源:百度百科-signal
参考资料来源:百度百科-sem_wait
wait操作和signal操作是计算机操作系统中进程控制的信号量机制的概念。
在进程控制中如何合理对共享资源分配便是一个关键的问题,所以引入了信号量的这个概念,通过pv操作便可以达到对空闲共享资源的合理分配。
一、信号量(semaphore)的数据结构为一个值和一个指针,指针指向等待该信号量的下一个进程。信号量的值与相应资源的使用情况有关。
1)、当它的值大于0时,表示当前可用资源的数量;
2)、当它的值小于0时,其绝对值表示等待使用该资源的进程个数。
二、PV操作,只有通过pv操作才可以改变信号量的值。
1)、p操作(wait):申请一个单位资源,进程进入。简而言之就是信号量减一。
2)、v操作(signal):释放一个单位资源,进程出来。简而言之就是信号量加一。
扩展资料
信号量分类
1、整型信号量
最初Dijkstra把整型信号量定义为一个用于表示资源数目的整型量S,它与一般的整型量不同,除初始化外,仅能通过两个标准原子操作(Atomic Operation)wait(S)和signal(S)操作。
2、记录型信号量
在整型信号量机制中的wait操作,只要是信号量S<=0,就会不断测试。因此,该机制并未遵循“让权等待”准则,而是使进程处于“忙等”状态。记录型信号量机制则是一种不存在“忙等”现象的进程同步机制。
3、AND型信号量
在一些应用场合,是一个进程需要先获得两个或者更多的共享资源后方能执行其任务。假定现在有两个进程A和B,他们都要求访问共享数据D和E。当然,共享数据都应该作为临界资源。为此,可为这两个数据分别设置用于互斥的信号量Dmutex和Emutex。
4、信号量集
在记录型信号量机制中,wait(S)或signal(S)操作仅能对信号量施以加1或者减1操作,意味着每次只能获得或释放一个单位的临界资源。而当一次需要N个某类临界资源时,便要进行N次wait(S)操作,显然这是低效的。此外,在有些情况下,当资源数量低于某一下限值时,便不予分配。
参考资料来源:百度百科-信号量机制
如果原来是0
那么就是wait(0)
还记得C语言中的while吗 while(0)就是不进入循环 一直等到while(1)再进入循环
(可以这么理解,但实际while直接不执行循环里的语句,跳过去了)
如果原来>0
直接减1,s的资源少了一个
如果原来<0
那么跟0一样还要等,等到大于0,继续执行。
signal(s)就是s加1
原理同上。
如果原来是0;
那么就是wait(0);
与C语言中的while很像, while(0)就是不进入循环 ,一直等到while(1)再进入循环可以这么理解,但实际while直接不执行循环里的语句,跳过去了)
如果原来>0;
直接减1,s的资源少了一个;
如果原来<0;
那么跟0一样还要等,等到大于0,继续执行。
signal(s)就是s加1;
原理同上。