linux 进程通信子mmap
生活随笔
收集整理的這篇文章主要介紹了
linux 进程通信子mmap
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
函數原型
釋放映射區
int munmap(void *addr, size_t length); 參數: addr 傳mmap的返回值 length mmap創建的長度 返回值:成功返回0失敗返回-1#include <unistd.h> #include <sys/types.h> int truncate(const char *path, off_t length); int ftruncate(int fd, off_t length);
這兩個函數可以根據文件描述符,或者是文件名,修改文件的大小(字節)
代碼示例:
寫端:
#include <sys/mman.h> #include <sys/stat.h> #include <sys/types.h> #include <string.h> #include <stdlib.h> #include <unistd.h> #include <stdio.h> #include <fcntl.h> #include <sys/wait.h> typedef struct _student {int sid;char sname[20]; }Student; int main(int argc, char *argv[]) {if(argc!=2) {printf("./a.out filename\n");return -1;}int fd = open(argv[1], O_RDWR|O_CREAT|O_TRUNC, 0666);int length = sizeof(Student);ftruncate(fd, length);Student *stu = mmap(NULL, length, PROT_WRITE|PROT_READ, MAP_SHARED, fd, 0);int num = 0;while (1){stu->sid = num++;sprintf(stu->sname, "mynames_x%d", num); sleep(1);}munmap(stu, length);close(fd);return 0; }讀端:
#include <sys/mman.h> #include <sys/stat.h> #include <sys/types.h> #include <string.h> #include <stdlib.h> #include <unistd.h> #include <stdio.h> #include <fcntl.h> #include <sys/wait.h> typedef struct _student {int sid;char sname[20]; }Student; int main(int argc, char *argv[]) {if(argc!=2) {printf("./a.out filename\n");return -1;}int fd = open(argv[1], O_RDONLY, 0666);int length = sizeof(Student);ftruncate(fd, length);Student *stu = mmap(NULL, length, PROT_READ, MAP_SHARED, fd, 0);int num = 0;while (1){printf("read sid= %d\n", stu->sid);printf("%s\n", stu->sname);sleep(1);}munmap(stu, length);close(fd);return 0; }ps:疑惑的地方 上面這端代碼最后釋放內存的這一部分,相當于多個進程對同一塊內存進行了重復釋放吧? 是這樣嗎?
ps2:疑惑的地方 mmap通過文件映射的內存位于哪塊內存區???
總結
以上是生活随笔為你收集整理的linux 进程通信子mmap的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 孟来财传奇剧情介绍
- 下一篇: linux信号学习02