Linux C 实现mysleep数
时间:2016-12-08 19:53 来源:linux.it.net.cn 作者:IT
先了解一下SIGALRM信号、alarm函数和pause函数。
-
SIGALRM
时钟定时信号, 计算的是实际的时间或时钟时间. alarm函数使用该信号.
-
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);
}
return 0;
}
(责任编辑:IT)
先了解一下SIGALRM信号、alarm函数和pause函数。
实现方法一:#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); } return 0; } (责任编辑:IT) |