Chinaunix首页 | 论坛 | 博客
  • 博客访问: 489289
  • 博文数量: 53
  • 博客积分: 492
  • 博客等级: 下士
  • 技术积分: 866
  • 用 户 组: 普通用户
  • 注册时间: 2011-11-14 15:12
文章分类

全部博文(53)

文章存档

2016年(1)

2015年(3)

2014年(17)

2013年(9)

2012年(7)

2011年(16)

我的朋友

分类: LINUX

2013-03-05 16:17:45

    在一个daemon程序中调用system来执行一段脚本,返回值总是-1.脚本简单的不能再简单了,只有一句exit 0,但还是返回-1.
查了很多资料,也没能找出原因,最后经过我反复的调试,终于发现了一个惊天动地的秘密!!

返回-1的原因是因为进程将SIGCHLD屏蔽了!!

确实我的程序在main函数里面就调用signal(SIGCHLD, SIG_IGN);将SIGCHLD屏蔽了!
system的调用过程主要是调三个函数
1.fork()
2.execl()
3.wait()
wait需要依赖SIGCHLD信号,所以屏蔽了SIGCHLD信号就永远得不到system正确的返回值了!

另外附一段正确判断脚本执行的方法:
system的返回值是按不同的字节置位的,0~7位和8~15位置的是不同的内容,判断脚本是否正确执行的正确做法是:

(1)-1 != status
(2)WIFEXITED(status)为真
(3)0 == WEXITSTATUS(status)

下面来解释一下后两个返回值的含义:

1,WIFEXITED(status) 这个宏用来指出子进程是否为正常退出的,如果是,它会返回一个非零值。

2,WEXITSTATUS(status) 当WIFEXITED返回非零值时,我们可以用这个宏来提取子进程的返回值,如果子进程调用exit(5)退出,WEXITSTATUS(status)就会返回5;如果子进程调用exit(7),WEXITSTATUS(status)就会返回7。



最后写了一段小的测试程序:
#include
using namespace std;
#include
#include
#include
#include
#include
int main()
{
    cout<<"pid: "<     int ret = 0;
    signal(SIGCHLD, SIG_IGN);
    ret = system("./wyf.sh");
    cout<<"ret: "<     return 0;
}

这段代码在2.6内核的系统上总是返回-1,但是奇怪的是在2.4内核的系统上返回0.



阅读(5116) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~