sleep函数的实现,先alarm定时器,然后pause暂停,SIGALAM的默认处理动作会导致进程退出,修改SIGALAM的处理方式,但是可以打断当前的阻塞操作,pause被打断,程序继续往下走。
但是这个sleep是有问题的。
alarm(3);
pause();
alarm(3);和pause();之间并不是原子操作,这时候来了一个其他信号,这个信号的回调函数只干了一件事,sleep(10);其实在睡到第3秒的时候,SIGALAM就已经注册了,但我们当前的程序阻塞在回调函数,完毕之后返回内核态,判断是否还有信号待处理,这时候就有一个SIGALAM信号。如果SIGALAM什么都没做,直接返回用户态的主流程,pause将陷入永久阻塞,因为不能唤醒了。
sigsuspend临时阻塞一些信号,然后陷入休眠,这是一个原子性操作。实现sleep的关键函数。