Linux C 实现mysleep函数

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);   
    }

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/79b3cf9f4b7684ebe43193cfe20cb1be.html