共享内存结构与指针问题

在项目开发中,使用包含指针的共享内存结构体时遇到运行时异常,原因在于各进程映射的共享内存起始地址不一致,导致指针失效。为解决此问题,可以调整结构体设计,将对象指针替换为对象本身,以避免因指针解析错误而引发的运行时错误。

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

【问题】在开发项目中自定义了包含指针的共享内存结构体,运行时异常导致程序崩溃。


共享内存结构体定义(伪代码):

struct shared_mem_buffer
{	
	shared_mem_buffer ()
	: read_sem_ (0)
	, write_sem_ (1)
	, mutex_sem_ (1)
	{					
	}

	ipc_semaphore  read_sem_;

	ipc_semaphore  write_sem_;

	ipc_semaphore  mutex_sem_;


	ipc_protocol *pkt_;   /* packet pointer */
}*sb_;

定义这个结构体本意是想在共享内存中构造对象并共享之(伪代码):

sb_->pkt_ = new (shm_start_addr + sizeof (shared_mem_buffer))ipc_protocol;  
/* shm_start_addr 是共享内存映射到进程的起始地址 */

这样编码看起来没有问题,但是运行很可能出错。


分析问题根源:  共享内存被映射到每个进程的起始地址可能不同,影响了从共享内存中读取的对象指针无法找到对象,
导致调用未知对象上的方法运行时错误。解决办法: 重新定义共享内存结构体,将对象指针改为对象(伪代码):

struct shared_mem_buffer
{	
	shared_mem_buffer ()
	: read_sem_ (0)
	, write_sem_ (1)
	, mutex_s
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值