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';
}

管道隐藏在构造函数、析构函数、beginend 方法中。