共享内存在java中的实现

59 篇文章 0 订阅

下面的代码实现了如上功能,它的作用类似UNIX系统中的mmap函数。

  // 获得一个只读的随机存取文件对象

  RandomAccessFile RAFile = new RandomAccessFile(filename,"r");

  // 获得相应的文件通道

  FileChannel fc = RAFile.getChannel();

  // 取得文件的实际大小,以便映像到共享内存

  int size = (int)fc.size();

  // 获得共享内存缓冲区,该共享内存只读

  MappedByteBuffer mapBuf = fc.map(FileChannel.MAP_RO,0,size);

  // 获得一个可读写的随机存取文件对象

  RAFile = new RandomAccessFile(filename,"rw");

  // 获得相应的文件通道

  fc = RAFile.getChannel();

  // 取得文件的实际大小,以便映像到共享内存

  size = (int)fc.size();

  // 获得共享内存缓冲区,该共享内存可读写

  mapBuf = fc.map(FileChannel.MAP_RW,0,size);

  // 获取头部消息:存取权限

  mode = mapBuf.getInt();

  如果多个应用映像同一文件名的共享内存,则意味着这多个应用共享了同一内存数据。这些应用对于文件可以具有同等存取权限,一个应用对数据的刷新会更新到多个应用中。

  为了防止多个应用同时对共享内存进行写操作,可以在该共享内存的头部信息加入写操作标志。该共享内存的头部基本信息至少有:

  int Length; // 共享内存的长度。

  int mode; // 该共享内存目前的存取模式。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值