共享内存在java中的实现

来源:互联网 发布:dnf端口破解 编辑:程序博客网 时间:2024/04/29 07:11

下面的代码实现了如上功能,它的作用类似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; // 该共享内存目前的存取模式。

原创粉丝点击