unsigned int alarm(unsigned int seconds);
alarm也称为闹钟函数,它可以在进程中设置一个定时器,当定时器指定的时间到时,它向进程发送SIGALRM信号。如果忽略或者不捕获此信号,则其默认动作是终止调用该alarm函数的进程。
int pause(void);
pause函数使调用进程挂起直到有信号递达。如果信号的处理动作是终止进程,则进程终止, pause函数没有机会返回;如果信号的处理动作是忽略,则进程继续处于挂起状态, pause不返回;如果信号的处理动作是捕捉,则调用了信号处理函数之后pause返回- 1 , errno设置为EINTR,所以pause只有出错的返回值(想想以前还学过什么函数只有出错回值?)。错误码EINTR表示“被信号中断”。
实现方法一:
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <signal.h>
void isr(int n)
{
return;
}
void mysleep(int nSeconds)
{
signal(SIGALRM,isr);
alarm(nSeconds); //nSeconds秒之后发送SIGALRM信号
pause(); //等待isr函数结束
return;
}
int main()
{
int nCount = 5;
while(nCount--)
{
printf("hello world\n");
mysleep(1);
}
return 0;
}
实现方法二:用vfork函数
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <signal.h>
void mysleep(int nSeconds)
{
pid_t pid = 0;
/** 产生子进程 */
pid = vfork();
if(pid == 0)
{
alarm(nSeconds);//alarm的默认动作是结束调用该函数的进程
pause(); //等待nSeconds之后,子进程结束,返回到父进程,实现mysleep功能
return;
}
}
int main()
{
int nCount = 5;
while(nCount--)
{
printf("hello world\n");
mysleep(1);
}
return 0;
}
实现方法三:用fork函数
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <signal.h>
void mysleep(int nSeconds)
{
pid_t pid = 0;
/** 产生子进程 */
pid = fork();
if(pid == 0)
{
alarm(nSeconds);//alarm的默认动作是结束调用该函数的进程
pause(); //等待nSeconds之后,子进程结束,
return;
}
else
{
wait(); //父进程一直等待着子进程结束
}
}
int main()
{
int nCount = 5;
while(nCount--)
{
printf("hello world\n");
mysleep(1);
}