④ 设计一个程序实现以下功能: 父进程创建三个子进程,父子进程间通过共享内存实现进程通信。该共享内存为长度为10 的整型数组,子进程1先往共享内存中存放数据1~10,接着子进程2从共享内存中读取数据1~5,然后子进程3从共享内存中读取数据6~10,最后由父进程撤销共享内存。注意父子进程间同步关系的实现。
时间: 2024-02-18 17:06:09 浏览: 70
利用共享内存实现进程通信
4星 · 用户满意度95%
以下是一个实现该功能的程序:
```c
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/shm.h>
#include <sys/wait.h>
#define SHM_SIZE 10
int main() {
int i, shmid;
int *shm;
pid_t pid[3];
// 创建共享内存
shmid = shmget(IPC_PRIVATE, SHM_SIZE * sizeof(int), IPC_CREAT | 0666);
if (shmid == -1) {
perror("shmget");
exit(EXIT_FAILURE);
}
// 将共享内存映射到当前进程
shm = shmat(shmid, NULL, 0);
if (shm == (int *)-1) {
perror("shmat");
exit(EXIT_FAILURE);
}
// 父进程创建三个子进程
for (i = 0; i < 3; i++) {
pid[i] = fork();
if (pid[i] < 0) {
perror("fork");
exit(EXIT_FAILURE);
} else if (pid[i] == 0) { // 子进程
if (i == 0) { // 子进程1
int j;
for (j = 0; j < SHM_SIZE; j++) {
shm[j] = j + 1; // 存放数据1~10
}
exit(EXIT_SUCCESS);
} else if (i == 1) { // 子进程2
int j;
for (j = 0; j < SHM_SIZE / 2; j++) {
printf("子进程2读取到数据:%d\n", shm[j]); // 读取数据1~5
}
exit(EXIT_SUCCESS);
} else if (i == 2) { // 子进程3
int j;
for (j = SHM_SIZE / 2; j < SHM_SIZE; j++) {
printf("子进程3读取到数据:%d\n", shm[j]); // 读取数据6~10
}
exit(EXIT_SUCCESS);
}
}
}
// 等待子进程结束
for (i = 0; i < 3; i++) {
waitpid(pid[i], NULL, 0);
}
// 删除共享内存
if (shmctl(shmid, IPC_RMID, NULL) == -1) {
perror("shmctl");
exit(EXIT_FAILURE);
}
return 0;
}
```
程序首先创建一个长度为10的整型数组作为共享内存,并将其映射到当前进程中。然后父进程创建三个子进程,分别对应存放数据、读取数据1~5和读取数据6~10。存放数据的子进程1直接将数据存入共享内存中,读取数据的子进程2和子进程3分别从共享内存中读取数据1~5和数据6~10。最后父进程等待三个子进程结束后,将共享内存删除。需要注意的是,为了实现父子进程间的同步关系,程序中使用了进程间通信的机制,即共享内存。
阅读全文