能够访问内存位置的Mmap系统调用操作

时间:2011-03-03 09:44:29

标签: c linux mmap

我正在编写一个程序,使用mmap分配大量内存,然后访问随机内存位置以读取和写入。  我刚刚尝试了以下代码:

#include <stdio.h>
#include <stdlib.h>
#include <sys/mman.h>

int main() {
    int fd,len=1024*1024;
         fd=open("hello",O_READ);
    char*addr=mmap(0,len,PROT_READ+PROT_WRITE,MAP_SHARED,fd,0);
    for(fd=0;fd<len;fd++)
putchar(addr[fd]);

    if (addr==MAP_FAILED) {perror("mmap"); exit(1);}

    printf("mmap returned %p, which seems readable and writable\n",addr);
    munmap(addr,len);

    return 0;
}

但我无法执行此程序,我的代码有什么问题吗?

1 个答案:

答案 0 :(得分:8)

首先,代码甚至不会在我的debian框中编译。据我所知,O_READ不是open()的正确标志。

然后,您首先使用fd作为文件描述符,并将其用作for循环中的计数器。

我不明白你要做什么,但我认为你误解了mmap的一些事情。

mmap用于将文件映射到内存中,这样您就可以读取/写入创建的内存映射,而不是使用函数来访问文件。

这是一个打开文件的短程序,将其映射到内存并打印返回者指针:

#include <stdio.h>
#include <stdlib.h>
#include <sys/mman.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>


int main() {
    int fd;
    int result;
    int len = 1024 * 1024;

    fd = open("hello",O_RDWR | O_CREAT | O_TRUNC, (mode_t) 0600);
    // stretch the file to the wanted length, writting something at the end is mandatory
    result = lseek(fd, len - 1, SEEK_SET);
    if(result == -1) { perror("lseek"); exit(1); }
    result = write(fd, "", 1);
    if(result == -1) { perror("write"); exit(1); }

    char*addr = mmap(0, len, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0);
    if (addr==MAP_FAILED) { perror("mmap"); exit(1); }

    printf("mmap returned %p, which seems readable and writable\n",addr);
    result = munmap(addr, len);
    if (result == -1) { perror("munmap"); exit(1); }

    close(fd);
    return 0;
}

我遗漏了for循环,因为我没有理解它的目的。由于您创建了一个文件,并且希望将其映射到给定长度,因此我们必须将文件“拉伸”到给定长度。

希望这有帮助。