任务
验证fork后父子进程的全局数据区及栈内存的共享情况。
具体描述:该实验创建2个进程,在父进程中创建一个全局变量,一个局部变量,并赋予初始值,用fork函数创建子进程。在子进程中对父进程的变量进行自加操作,并且输出变量值,后在父进程睡眠一段时间,再输出两个变量,观察子进程和父进程的输出变量值。
相关知识:
getpid //返回当前进程标识;
getppid //返回父进程标识。
sleep //执行挂起指定的秒数
由f o r k创建的新进程被称为子进程(child process)。该函数被调用一次,但返回两次。两次返回的区别是子进程的返回值是0,而父进程的返回值则是新子进程的进程I D。将子进程I D返回给父进程的理由是:因为一个进程的子进程可以多于一个,所以没有一个函数使一个进程可以获得其所有子进程的进程I D。f o r k使子进程得到返回值0的理由是:一个进程只会有一个父进程,所以子进程总是可以调用g e t p p i d以获得其父进程的进程I D (进程ID 0总是由交换进程使用,所以一个子进程的进程I D不可能为0 )。子进程和父进程共享很多资源,除了打开文件之外,很多父进程的其他性质也由子进程继承
审核要求:
- 提交全部程序代码,代码思路规范清晰,命名规范。
- 运行能直接输出所要求的结果。
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<sys/types.h>
pid_t getpid(void);
pid_t getppid(void);
int global = 10;
char buf[] = "a write to stdout\n";
int main(){
int status;
int var;
pid_t pid;
var = 88;
printf("%s",buf);
printf("before fork\n");
pid = fork();
if(0 == pid){
global++;
var++;
printf("now is child process\n");
printf("I am son,id is %d,my parent id is %d,global=%d,global addresss is 0x%x,var = %d,var address is 0x%x\n",getpid(),getppid(),global,&global,var,&var);
}
else if(0 > pid){
printf("fork failed\n");
}
else{
pid = wait(&status);
printf("now is father process\n");
printf("I am parent,id id %d,global = %d,global address is 0x%x,var = %d,var addresss is 0x%x\n",getpid(),global,&global,var,&var);
}
return 0;
}