共享内存在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; // 该共享内存目前的存取模式。
- 共享内存在java中的实现
- 共享内存在java中的实现
- 共享内存在java中的实现
- 共享内存在java中的实现
- 共享内存在java中的实现
- 共享内存在Java中的实现和应用
- 共享内存在Java中的实现和应用
- java实现共享内存
- 使用技巧:共享内存在Java中实现和应用
- 共享内存在Java中实现和应用
- 共享内存在Java中实现和应用
- 共享内存在Java中实现和应用
- 共享内存在Java中实现和应用
- 共享内存在Java中实现和应用
- 共享内存在Java中实现和应用
- 共享内存在Java中实现和应用
- 在共享内存中实现hash表
- 在共享内存实现 Redis(上)
- VC++的链接错误LNK2005
- Linux 下 如何打 PATCH 及制作 DIFF
- 技术团队组建过程
- Win7下安装SQLServer2005_SSMSEE.msi
- helloworld
- 共享内存在java中的实现
- MES应用的春天已经到来
- nginx rewrite
- PERL编程24学时教程-读书笔记(三)
- Ling to SQL 更新数据库操作
- 爱(张爱玲)
- 今天公司年会
- 这些道理不懂,你注定就是穷打工的命
- LINQ to SQL公共基类