交易系统开发技能及面试之进程间通信(共享内存)

共享内存是最快的进程通信方式,常用于交易系统开发。本文探讨当最后一个附加进程退出时的情况,内存共享的运行时调整,mmap的优势以及在写内存时的行为。还讨论了操作系统为何需要虚拟内存,以及ABI与API的区别。
摘要由CSDN通过智能技术生成

摘要

共享内存是进程间通信的最常用的方式,所以其在面试中也是高频知识点。通常,共享内存的使用场景多用于持久化进程的内存数据,以及实现进程间通信的共享内存队列中间件。

Q1 当最后一个附加到共享内存的进程意外退出时,会发生什么?

windows时,共享内存是通过FileMapping 实现的,可以调用CreateFileMapping 创建一个内存文件映射对象。这个对象是由内存管理的,当使用这个对象的进程意外退出时,这个对象是持续存在未销毁的,需要调用CloseHandle关闭内核对象句柄。

同理在Linux中,共享内存是通过shmget创建一个共享内存对象,需要通过调用shmctl来释放掉,否则当附加进程意外退出时该对象仍然存在。

Q2 为什么内存共享是最快的进程通讯方式?

因为共享内存不需要将数据从进程A拷贝到进程B,而仅需要考虑进程间对共享内存的竞争问题,通常采用信号量的方式实现进程间同步互斥。

Q3 可以在运行时调整共享内存大小么?

共享内存在创建时就确定了大小,不能在运行时修改

Q4 使用mmap实现进程间通讯有什么优点?当一个进程正在写内存时会发生什么?

mmap()是一种内存映射文件的方法,即将一

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值