shmget 就是得到一个内存区, KEY相同情况下,各进程访问的是同一块内存。造型为指定类型后,直接操作访问。注意: 访问进程间要加锁。这个锁也必须是共享内存锁。参考吾其他博文。 写数据时,结构体中的缓冲区必须是已经声明足够大小,而不是一个指针需要时malloc。因为malloc的地址,其他进程访问不到。
在跨用户访问共享内存时,shm_open会好一些,因为它的文件是放在/dev/shm的这么一个公共目录。 shmget还要特意找一个区域让多用户共享,然后再生成个不会被删除的文件来生成共享key,这样不如shm_open来的直接和明确。
因为进程可以直接读写内存,而不需要任何数据的拷贝。
int main(void) { fd = open(“/mnt/huge/test.txt”, O_CREAT|O_RDWR); addr=mmap(0,MAP_LENGTH,PROT_READ|PROT_WRITE,MAP_SHARED, fd, 0); return 0; } 这里需要注意是,通过 mmap 映射 hugetlbfs 中的文件的时候,并不需要指定 MAP_HUGETLB 。而我们通过 SYSV 标准的系统调用 shmget 和 shmat ...
同是共享内存,shm_open与shmget有什么差异? 因为工作需要,这几天研究了一下共享内存。搞得自己也有点糊涂。糊涂在哪里?有两个共享内存的东西。仔细研究了之后,初步结论如下。shm_open:把共享内存以文件方式打开,这样就可以直接向文件中写入数据了。有以下注意事项: 从了解的资料来看,硬盘可能有对应的文件。如果是真...
1. shmget 该函数用来创建共享内存:intshmget(key_t key, size_t size,intshmflg); 参数: key : 和信号量一样,程序需要提供一个参数key, 它有效地为共享内存段命名。 有一个特殊的键值IPC_PRIVATE, 它用于创建一个只属于创建进程的共享内存, 通常不会用到。
int main(void) { fd = open(“/mnt/huge/test.txt”, O_CREAT|O_RDWR); addr=mmap(0,MAP_LENGTH,PROT_READ|PROT_WRITE,MAP_SHARED, fd, 0); return 0; } 这里需要注意是,通过 mmap 映射 hugetlbfs 中的文件的时候,并不需要指定 MAP_HUGETLB 。而我们通过 SYSV 标准的系统调用 shmget 和 shmat ...
_create(_key+2);sem_setval(sem_empty, 0); } else { //共享内存已经存在,并且打开成功, 则只需需将其连接到进程的地址空间p_shm= (shmhead_t... == -1) err_exit("shmget error"); //创建共享内存成功, 则需要将其连接到进程的地址空间p_shm= (shmhead_t *)shmat ...
我对POSIX shm_open、mmap API系列的共享内存的喜爱,远远超过SYS V 100倍。原谅我就是一个懒惰的人,我就是讨厌ftok、shmget、shmat、shmdt这样的API。 上面的程序如果用POSIX的写法,可以简化成写端psw.c: 读端: 编译和执行: 这样我们会在/dev/shm/、/run/shm下面看到一个文件: ...