Chinaunix首页 | 论坛 | 博客
  • 博客访问: 310005
  • 博文数量: 55
  • 博客积分: 4000
  • 博客等级: 上校
  • 技术积分: 615
  • 用 户 组: 普通用户
  • 注册时间: 2008-01-07 13:47
文章分类
文章存档

2011年(1)

2010年(2)

2009年(14)

2008年(38)

我的朋友

分类: LINUX

2008-04-01 11:48:55

创建一个进程的系统调用很简单.我们只要调用fork 函数就可以了.
#include ;
pid_t fork();
当一个进程调用了fork 以后,系统会创建一个子进程.这个子进程和父进程不同的地方只
有他的进程ID 和父进程ID,其他的都是一样.就象父进程克隆(clone)自己一样.当然创建
两个一模一样的进程是没有意义的.为了区分父进程和子进程,我们必须跟踪fork 的返回
值. 当fork 掉用失败的时候(内存不足或者是用户的最大进程数已到)fork 返回-1,否则f
ork 的返回值有重要的作用.对于父进程fork 返回子进程的ID,而对于fork 子进程返回0.我
们就是根据这个返回值来区分父子进程的. 父进程为什么要创建子进程呢?前面我们已经
说过了Linux 是一个多用户操作系统,在同一时间会有许多的用户在争夺系统的资源.有时
进程为了早一点完成任务就创建子进程来争夺资源. 一旦子进程被创建,父子进程一起从
fork 处继续执行,相互竞争系统的资源.有时候我们希望子进程继续执行,而父进程阻塞直
到子进程完成任务.这个时候我们可以调用wait 或者waitpid 系统调用.
#include ;
#include ;
pid_t wait(int *stat_loc);
pid_t waitpid(pid_t pid,int *stat_loc,int options);
wait 系统调用会使父进程阻塞直到一个子进程结束或者是父进程接受到了一个信号.如果
没有父进程没有子进程或者他的子进程已经结束了wait 回立即返回.成功时(因一个子进
程结束)wait 将返回子进程的ID,否则返回-1,并设置全局变量errno.stat_loc 是子进程的
退出状态.子进程调用exit,_exit 或者是return 来设置这个值. 为了得到这个值Linux 定
义了几个宏来测试这个返回值.
WIFEXITED:判断子进程退出值是非0
WEXITSTATUS:判断子进程的退出值(当子进程退出时非0).
WIFSIGNALED:子进程由于有没有获得的信号而退出.
WTERMSIG:子进程没有获得的信号号(在WIFSIGNALED 为真时才有意义).
waitpid 等待指定的子进程直到子进程返回.如果pid 为正值则等待指定的进程(pid).如果
为0 则等待任何一个组ID 和调用者的组ID 相同的进程.为-1 时等同于wait 调用.小于-1 时等
待任何一个组ID 等于pid 绝对值的进程. stat_loc 和wait 的意义一样. options 可以决定
父进程的状态.可以取两个值 WNOHANG:父进程立即返回当没有子进程存在时.
WUNTACHED:当子进程结束时waitpid 返回,但是子进程的退出状态不可得到.
waitpid 等待指定的子进程直到子进程返回.如果pid 为正值则等待指定的进程(pid).如果
为0 则等待任何一个组ID 和调用者的组ID 相同的进程.为-1 时等同于wait 调用.小于-1 时等
待任何一个组ID 等于pid 绝对值的进程. stat_loc 和wait 的意义一样. options 可以决定
父进程的状态.可以取两个值 WNOHANG:父进程立即返回当没有子进程存在时.
WUNTACHE
D:当子进程结束时waitpid 返回,但是子进程的退出状态不可得到.
统调用exec 族调用.exec 族调用有这5 个函数.
#include ;
int execl(const char *path,const char *arg,...);
int execlp(const char *file,const char *arg,...);
int execle(const char *path,const char *arg,...);
int execv(const char *path,char *const argv[]);
int execvp(const char *file,char *const argv[]);
exec族可以执行指定程序
一个例子:
#include ;
#include ;
#include ;
#include ;
#include ;
#include ;
void main(void)
{
pid_t child;
int status;
printf("This will demostrate how to get child status\n");
if((child=fork())==-1)
{
printf("Fork Error :%s\n",strerror(errno));
exit(1);
}
else if(child==0)
{
int i;
printf("I am the child:%ld\n",getpid());
for(i=0;i<1000000;i++) sin(i);
i=5;
printf("I exit with %d\n",i);
exit(i);
}
while(((child=wait(&status))==-1)&(errno==EINTR));
if(child==-1)
printf("Wait Error:%s\n",strerror(errno));
else if(!status)
printf("Child %ld terminated normally return status is zero\n",
child);
else if(WIFEXITED(status))
printf("Child %ld terminated normally return status is %d\n",
child,WEXITSTATUS(status));
else if(WIFSIGNALED(status))
printf("Child %ld terminated due to signal %d znot caught\n",
child,WTERMSIG(status));
}
阅读(801) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~