Bootstrap

linux c 进程学习

1.fork

由于fork后的父进程与子进程的优先级是一样的,所以会存在父进程已经退出了而子进程还在执行,这时候的子进程就是孤儿进程,会被init进程收养,所以这时候getppid得到的1。

int main(){
	pid_t pid;
	pid = fork();
	switch(pid){
		case 0:
			printf("孩子进程,pid:%d,父进程pid:%d\n",getpid(),getppid());
		break;	
		case -1:
			printf("进程创建失败。\n");
		break;	
		default:
			printf("父亲进程,pid:%d,孩子进程pid:%d\n",getpid(),pid);
			wait(NULL);		//等待子进程 防止孤儿进程
		break;	
	}
	exit(0);
}

  2.vfork

由vfork也是用来创建进程,但是子进程是共享父进程的地址空间,也就是两者的变量是共享的,而fork是复制的两者不共享。vfork会保证子进程先执行,当子进程 exec 或者 exit后才可能会被调度,如果未调用exec 或者 exit 将出现段错误。


int glab_var = 0;
int main(){
	int i=0;
	int var = 0;
	pid_t pid;
	pid = vfork();
	switch(pid){
		case 0:
			printf("pid:%d\n",getpid());
			printf("ppid:%d\n",getppid());
			printf("孩子 i:%d\n",i);
			while(i<5){
				i++;
				var++;glab_var++;			
			}
			printf("孩子  var:%d,glab:%d\n",var,glab_var);
			exit(0);
		break;	
		case -1:
			exit(0);
		break;	
		default:
			printf("pid:%d\n",getpid());
			printf("cpid:%d\n",pid);
			printf("父亲 i:%d\n",i);
			i=0;
			while(i<3){
				i++;
				var++;glab_var++;			
			}
			printf("父亲  var:%d,glab:%d\n",var,glab_var);
			//wait(NULL);
			exit(0);
		break;	
	}
}

;