使用vfork函数时出现总线异常

使用vfork函数时出现总线错误

在学习进程编程的时候,发现了一个有意思的事情,代码如下:

#include <unistd.h>
#include <stdio.h>
main()
{
	if( vfork() ==0 )
	{
		printf(“This is the child process\n”);
	}
	else
	{
		printf(“This is the parent process\n”);
	}

	return 0;
}

这个程序看似没有任何问题,但在Centos 6.3系统中实际运行时错误还很惊人!他会一直不停地交互输出那两句话,一直输出了有五万多行!!!!!然后我把源程序拷贝到RHEL5中运行时,这时报错了说是总线错误,仔细查看了APUE之后才知道真正的原因!!

先看vfork和fork的区别和相同点:

区别:
    1、fork()用于创建一个新进程。由fork()创建的子进程是父进程的副本。即子进程获取父进程数据空间,堆和 栈的副本。父子进程之间不共享这些存储空间的部分。而vfork()创建的进程并不将父进程的地址空间完全复制到子进程中,因为子进程会立即调用exec (或exit)于是也就不会存放该地址空间。相反,在子进程调用exec或exit之前,它在父进程的空间进行。
    2、vfork()与fork()另一个区别就是:vfork保证子进程先运行,在调用exec或exit之前与父进程数据是共享的,在它调用exec或exit之后父进程才可能被调度运行。
    3,vfork和fork之间的还有一个区别是: vfork保证子进程先运行,在她调用exec或exit之后父进程才可能被调度运行。如果在调用这两个函数之前子进程依赖于父进程的进一步动作,则会导致死锁。
相同:
    1、两者被调用一次,但是返回两次。两次返回的唯一区别是子进程的返回值是0,而父进程的返回值则是新子进程的进程ID。

再去查阅有关信号量的章节时,发现问题了:

这是因为父进程执行了return时,执行了一个无效的内存引用,信号为 SIGSEGV 默认动作是异常终止,解决的办法是将return改exit即可。