mmap效果

我们首先使用mmap直接访问索引文件代替将索引读到内存再进行操作的方式。

实际的实验表明,mmap的使用能够有效地加快io的速度,特别是在 全部索引文件不到20g的情况下,在内存为16G的测试机上,整个压力测试的过程中wa基本保持在1以下。

Linux的mmap是一种内存映射文件的方法,通过将一个文件或者其他对象映射到进程的地址空间,实现磁盘的地址和进程虚拟地址空间的一一对应关系。通过使用mmap系统调用,进程可以将同一个普通文件映射到它们的地址空间中,从而实现共享内存的效果。一旦文件被映射到进程的地址空间中,进程可以像访问普通内存一样对文件进行读写操作。 在Linux中,通过调用内核的mmap函数来进行内存映射,其函数原型为int mmap(struct file *filp, struct vm_area_struct *vma)。需要注意的是,这里的mmap是内核态的mmap,并非用户态的mmap。 下面是一个演示映射到物理内存的案例: ```cpp #include <iostream> #include <sys/mman.h> #include <cstring> #include <cerrno> #include <cstdio> using namespace std; static const int SIZE = 4096; int main() { char *str = (char *)mmap(NULL, SIZE, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS, 0, 0); // 注意MAP_PRIVATE和MAP_ANONYMOUS // 建立映射 if (str == MAP_FAILED) { printf("%s\n", strerror(errno)); return -2; } strcpy(str, "hello ksy"); puts(str); // 用于取消映射 munmap(str, SIZE); return 0; } ``` 以上代码使用mmap将一段物理内存映射到进程的地址空间中,然后将字符串"hello ksy"写入到这段映射的内存中,并 #### 引用[.reference_title] - *1* *2* *3* [Linux下mmap](https://blog.csdn.net/qq_56999918/article/details/127070280)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值