当前位置: > Linux编程 >

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)
------分隔线----------------------------