操作系统中fork()用来创建子进程,大致过程是子进程复制父进程的内存内容到一块新的内存。下面来看一下我在学操作系统时碰到的问题:
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
main()
{
int pid;
int i;
char *flag[] = {"Parent:","Child:"};
pid = fork();
if (pid == 0)
i = 0;
else
i = 1;
printf("%s:i=%d,&i=%d\n",flag[i],i,&i);
}
下面是运行的结果:
$ ./systest
Child::i=1,&i=2337496
Parent::i=0,&i=2337496
注:&i的地址在每台计算机可能都不一样,但是子进程和父进程的&i是一样的。
根据运行结果可以看出,i值不一样,然而i的地址是一样的,这是怎么回事呢?
查过资料后发现,原来i的地址只是虚拟地址,不是真正的物理地址。地址的
表示方式为基址+偏移量(虚拟地址),子进程只是把父进程的变量的虚拟地址复
制下来放到与父进程不同的基址中,所以子进程与父进程的i变量所指向的只
是虚拟地址一样,其物理地址是不一样的。
注:在windows环境下编译这个程序出现了一个小问题,不能识别fork()函数,
还好我的电脑里面装了cygwin(模拟linux环境的软件),然后用cygwin的gcc命
令编译的。