注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

小白的博客

嵌入式爱好者

 
 
 

日志

 
 

进程创建——fork函数解析  

2012-09-29 15:08:55|  分类: 应用层的简单介绍 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
首先我们说下fork的功能,很简单,就是创建子进程!但是它有个特点,那就是调用一次返回两次,我们先来看代码:

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

int main(int argc , char **argv)
{
int id;
id=fork();
if(id<0)
{
printf("fork error\n");
}
else if(id==0)
{
printf("I'm in child process\n");
}
else
{
printf("I'm in parent process\n");
}

return 0;
}

这段代码的执行结果是:
I'm in parent process
I'm in child process

那么很显然这段代码至少被执行了两次,否则不可能进行两次判断!实际上这段代码确实被执行了两次,fork()创建了一个子进程,现在就存在两个进程了,fork()会向父进程返回子进程id,向子进程返回0。也就是说,我们可以判断fork()的返回值来判断此时是在父进程中还是子进程中!

我们知道一个程序有代码段、数据段和堆栈段,代码段被父子进程贡献,那么数据段和堆栈段呢?我们来看下面的程序:

#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
static int count = 0;
int main(int argc , char **argv)
{
int id;

id=fork();
if(id<0)
{
printf("fork error\n");
}
else if(id==0)
{
count++;
printf("I'm in child process\n");
printf("child count=%d\n",count);
}
else
{
count++;
printf("I'm in parent process\n");
printf("parent count=%d\n",count);
}

return 0;
}

结果是:
I'm in child process
child count=1
I'm in parent process
parent count=1

很显然,如果数据段是共享的话,那么两次打印的count的值肯定有一个为2,现在都是1就说明数据段是独立的,同样其实堆栈段也是独立的!fork()函数会将父进程的数据段和代码段拷贝过来,作为子进程独立的数据段和代码段!
  评论这张
 
阅读(973)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017