实验六 进程通信-共享内存机制
时间: 2023-10-01 13:03:46 浏览: 114
共享内存机制是一种进程间通信的方式,可以让多个进程共享同一块内存区域,从而实现数据的传递和交换。在共享内存机制中,多个进程可以访问同一块内存区域,实现数据共享。下面是一个简单的共享内存机制的示例代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/shm.h>
#include <string.h>
#define SHM_SIZE 1024
#define SHM_KEY 1234
int main()
{
int shmid;
char *shmaddr;
char *msg = "Hello, shared memory!";
// 创建共享内存
shmid = shmget(SHM_KEY, SHM_SIZE, IPC_CREAT | 0666);
if (shmid == -1) {
perror("shmget");
exit(EXIT_FAILURE);
}
// 连接共享内存
shmaddr = shmat(shmid, NULL, 0);
if (shmaddr == (char *)(-1)) {
perror("shmat");
exit(EXIT_FAILURE);
}
// 写入数据
memcpy(shmaddr, msg, strlen(msg) + 1);
// 断开共享内存连接
if (shmdt(shmaddr) == -1) {
perror("shmdt");
exit(EXIT_FAILURE);
}
return 0;
}
```
在上面的示例代码中,我们创建了一个大小为1024字节的共享内存,然后将其连接到当前进程的地址空间中,将字符串“Hello, shared memory!”写入共享内存中,并最终断开共享内存的连接。其他进程可以通过相同的key来连接同一块共享内存,从而实现数据共享。
需要注意的是,在使用共享内存机制时,需要考虑到多个进程同时访问同一块内存区域可能带来的同步问题,需要采取相应的同步机制来保证数据的一致性。
阅读全文