在Linux中,我们可以使用shmget()、shmat()、shmdt()和shmctl()这四个系统调用来实现共享内存的使用。
- shmget()
shmget()函数用来创建或获取一个共享内存标识符。其原型如下:
int shmget(key_t key, size_t size, int shmflg);
- key:是一个键值,用来标识共享内存,进程可以通过这个键值来获取共享内存。
- size:是所创建的共享内存的大小,单位是字节。
- shmflg:是操作标志,如果是创建共享内存,它的值通常是0666。如果是获取已经创建的共享内存,它的值通常是0。
返回值:成功返回一个非负整数,即共享内存的ID;失败返回-1。
- shmat()
shmat()函数用来把共享内存映射到当前进程的地址空间。其原型如下:
void *shmat(int shmid, const void *shmaddr, int shmflg);
- shmid:是shmget()返回的共享内存标识符。
- shmaddr:是要映射的地址,通常设置为NULL,让系统自动选择合适的地址。
- shmflg:是映射标志,比如SHM\_RDONLY表示以只读方式映射。
返回值:成功返回一个指向共享内存的指针;失败返回-1。
- shmdt()
shmdt()函数用来断开共享内存映射。其原型如下:
int shmdt(const void *shmaddr);
- shmaddr:是shmat()返回的共享内存地址。
返回值:成功返回0;失败返回-1。
- shmctl()
shmctl()函数用来控制共享内存。其原型如下:
int shmctl(int shmid, int cmd, struct shmid_ds *buf);
- shmid:是shmget()返回的共享内存标识符。
- cmd:是控制命令,如IPC\_STAT、IPC\_SET、IPC\_RMID等。
- buf:是共享内存的数据结构,通常为NULL。
返回值:成功返回0;失败返回-1。
以下是一个简单的使用这四个函数的例子:
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <string.h>
int main() {
key_t key = ftok("shmfile", 65);
int shmid = shmget(key, 1024, 0666 | IPC_CREAT);
if (shmid < 0) {
perror("shmget");
exit(1);
}
char *p = (char *)shmat(shmid, NULL, 0);
if (p < 0) {
perror("shmat");
exit(1);
}
strcpy(p, "Hello, Shared Memory!");
if (shmdt(p) < 0) {
perror("shmdt");
exit(1);
}
if (shmctl(shmid, IPC_RMID, NULL) < 0) {
perror("shmctl");
exit(1);
}
return 0;
}
这个例子中,我们首先通过ftok()获