加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Windows > 正文

Windows环缓冲区无需复制

发布时间:2020-12-14 04:20:51 所属栏目:Windows 来源:网络整理
导读:在 Ring Buffer’s Wikipedia entry,有 example code显示 UNIX系统的黑客,其中相邻虚拟内存到一块内存是 mapped到相同的物理内存,因此实??现了一个环形缓冲区而不需要任何 memcpy等.我想知道是否有办法在 Windows这么类似的东西? 谢谢,弗雷泽 我并没有真正
在 Ring Buffer’s Wikipedia entry,有 example code显示 UNIX系统的黑客,其中相邻虚拟内存到一块内存是 mapped到相同的物理内存,因此实??现了一个环形缓冲区而不需要任何 memcpy等.我想知道是否有办法在 Windows这么类似的东西?

谢谢,弗雷泽

我并没有真正遵循维基百科中的示例的所有细节.考虑到这一点,您使用 CreateFileMapping和 MapViewOfFile在Windows中映射内存,但MapViewOfFile不允许您为映射指定基址. MapViewOfFileEx可用于指定基址,因此您可以使用类似的技术.

我没有办法告诉这是否真的有效:

// determine valid buffer size
SYSTEM_INFO info;
GetSystemInfo(&info);

// note that the base address must be a multiple of the allocation granularity
DWORD bufferSize=info.dwAllocationGranularity;

HANDLE hMapFile = CreateFileMapping(
             INVALID_HANDLE_VALUE,NULL,PAGE_READWRITE,bufferSize*2,L"Mapping");

BYTE *pBuf = (BYTE*)MapViewOfFile(hMapFile,FILE_MAP_ALL_ACCESS,bufferSize);
MapViewOfFileEx(hMapFile,bufferSize,pBuf+bufferSize);

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读