Chinaunix

标题: 线程不能挂起 [打印本页]

作者: yanghs.dgut    时间: 2007-04-21 09:41
标题: 线程不能挂起
下面是一段测试程序, 主进程创建一个子进程,子进程创建一个线程。
问题是:主进程向子进程发中断信号后, 子进程的线程不暂停,还在继续执行。
        我觉得理论上有点说不过去。
        那位能给我说说怎么回事?


#include <stdio.h>
#include <signal.h>
#include <unistd.h>
#include <sys/types.h>
#include <pthread.h>

void stop(int signumber)
{
        puts("stop a moment") ;
        pause() ;
}

void comeon(int signumber)
{
        puts("go on") ;
        return ;
}

void *print()
{
        int i = 0 ;
        while(1)
        {
                printf("hello world%d\n", i++);
                sleep(1) ;
        }
        return ;
}

int main()
{
        pid_t pid ;


        if((pid = fork()) == 0)
        {
                pthread_t th_hello ;

                if(signal(SIGCONT, &comeon) == SIG_ERR)
                        puts("comeon error") ;

                if(signal(SIGINT, &stop) == SIG_ERR)
                        puts("stop error") ;

                pthread_create(&th_hello, NULL, print, 0);
                pthread_join(th_hello, NULL);
                                
        }
        else if( pid > 0)
        {

                sleep(4) ;
                kill(pid, SIGINT) ;
        }
        return 0 ;

}
作者: cugb_cat    时间: 2007-04-21 13:37
父进程向子进程发的信号不一定所有线程都能收到,我觉得应该是只有一个线程能接收到。
作者: yanghs.dgut    时间: 2007-04-21 22:20
楼上兄台说得对,刚测试了一下确是只有主线程收到。
不过问题还未解决。
我要实现的功能是这样的:

线程被创建执行后,先挂起,然后收到一个信号(如SIGCONT)后运行, 如再收到一个信号(SIGINT)线程又挂起。如此循环。 请问有什么方法可以实现,用到那个函数。那位给我说说,先谢谢了
作者: redhat008    时间: 2007-04-22 10:28
这个需要sigmask来实现的。。
看APUE signal部分
作者: ddvv    时间: 2007-04-22 10:30
原帖由 cugb_cat 于 2007-4-21 13:37 发表
父进程向子进程发的信号不一定所有线程都能收到,我觉得应该是只有一个线程能接收到。


线程和进程的概念怎么混在一起了????????
作者: redhat008    时间: 2007-04-22 10:40
原帖由 ddvv 于 2007-4-22 10:30 发表


线程和进程的概念怎么混在一起了????????


我觉得楼上的没有混在一起啊。。。

是,只有一个进程才能接收信号,不过在一个进程上下文中某一时间点上只有一个线程实例在运行的。。
也就是一个线程接收到该信号。。只是是不是被block了,应该根据每个线程的sigmask来定的。。。




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2