mmap的简明指针算法
Concise pointer arithmetic for mmap
我试图mmap
一块内存,然后使用指针算法将其视为一个数组。 mmaped 区域的大小将由应用程序更改,因为可能会传递不同的大小和数据类型。这是我到目前为止所做的工作,但是,我认为可能有更好的方法。
#include <iostream>
#include <sys/mman.h>
int main(int argc, char** argv) {
int num_ints = 10;
int num_bytes = num_ints * sizeof(int);
void *base = mmap(0, num_bytes, PROT_READ | PROT_WRITE,
MAP_ANONYMOUS | MAP_PRIVATE, -1, 0);
// Ugly way
for(int i = 0; i < num_ints; i++)
{
*((int *) base + i) = i;
std::cout << *((int *) base + i) << " " << ((int *) base + i) << std::endl;
}
std::cout << std::endl;
// A better way
int *ptr = (int *) base;
for(int i = 0; i < num_ints; i++)
{
*(ptr + i) += i;
std::cout << *(ptr + i) << " " << (ptr + i) << std::endl;
}
// What I'm looking is base[i] = i; which leads to
// warning: pointer of type 'void *' used in arithmetic [-Wpointer-arith]
// error: 'void*' is not a pointer-to-object type
munmap(base, num_bytes);
return(0);
}
有没有更简洁的实现方法的建议?
真的没有多少了,是吗?
关于缩短它的唯一方法是 std::iota(ptr, ptr+num_ints, 0)
。在这里对你帮助不大,因为你仍然有用于打印目的的循环。
一种更工业化的方法是将逻辑包装在 class 模板中,类似于 std::array<T, n>
。这可能会将您的程序变成
int main(int argc, char** argv)
{
mmarray<int,10> ints;
std::iota(begin(ints), end(ints), 0);
for(int i: ints) std::cout << i << '\n';
}
管道隐藏在构造函数、析构函数、begin
和 end
方法中。
我试图mmap
一块内存,然后使用指针算法将其视为一个数组。 mmaped 区域的大小将由应用程序更改,因为可能会传递不同的大小和数据类型。这是我到目前为止所做的工作,但是,我认为可能有更好的方法。
#include <iostream>
#include <sys/mman.h>
int main(int argc, char** argv) {
int num_ints = 10;
int num_bytes = num_ints * sizeof(int);
void *base = mmap(0, num_bytes, PROT_READ | PROT_WRITE,
MAP_ANONYMOUS | MAP_PRIVATE, -1, 0);
// Ugly way
for(int i = 0; i < num_ints; i++)
{
*((int *) base + i) = i;
std::cout << *((int *) base + i) << " " << ((int *) base + i) << std::endl;
}
std::cout << std::endl;
// A better way
int *ptr = (int *) base;
for(int i = 0; i < num_ints; i++)
{
*(ptr + i) += i;
std::cout << *(ptr + i) << " " << (ptr + i) << std::endl;
}
// What I'm looking is base[i] = i; which leads to
// warning: pointer of type 'void *' used in arithmetic [-Wpointer-arith]
// error: 'void*' is not a pointer-to-object type
munmap(base, num_bytes);
return(0);
}
有没有更简洁的实现方法的建议?
真的没有多少了,是吗?
关于缩短它的唯一方法是 std::iota(ptr, ptr+num_ints, 0)
。在这里对你帮助不大,因为你仍然有用于打印目的的循环。
一种更工业化的方法是将逻辑包装在 class 模板中,类似于 std::array<T, n>
。这可能会将您的程序变成
int main(int argc, char** argv)
{
mmarray<int,10> ints;
std::iota(begin(ints), end(ints), 0);
for(int i: ints) std::cout << i << '\n';
}
管道隐藏在构造函数、析构函数、begin
和 end
方法中。