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

本文详细分析了vfork和fork函数的区别,解释了在Centos6.3系统中vfork函数运行时出现的错误原因,并提供了解决方案。通过改变return语句为exit,避免了内存引用无效的问题,从而解决了错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

#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即可。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值