2、在以下程序中使用系统调用lockf()来给进程加锁,实现进程之间的互斥,观察并分析出现的现象 #include<stdio.h> main() { int p1,p2,i; while((p1==fork())==-1); if(p1==0) for(i=0;i<500;i++) printf("child%d\n",i); else {while((p2==fork())==-1); if(p2==0) for(i=0;i<500;i++) printf("son%d\n",i); else for(i=0;i<500;i++) printf("daughter%d\n",i); } }
时间: 2023-06-22 17:22:51 浏览: 306
预备进程控制-操作系统誊抄实验
这个程序会创建三个进程:一个父进程和两个子进程。父进程会创建两个子进程,其中一个子进程会输出"son",另一个子进程会输出"daughter",而父进程会输出"child"。这三个进程会同时运行,输出的顺序是随机的。
如果我们在程序中使用lockf()系统调用来给进程加锁,会出现如下现象:每个进程都会在执行printf()函数之前调用lockf()函数,给共享的输出资源加锁,避免多个进程同时写入。当一个进程获得了锁,其他进程就会被阻塞,直到锁被释放。这样就可以保证输出的顺序是固定的。
修改后的程序如下:
#include <stdio.h>
#include <unistd.h>
#include <fcntl.h>
int main() {
int p1, p2, i;
int fd = open("output.txt", O_WRONLY | O_CREAT | O_TRUNC, 0666); // 打开一个输出文件
if (fd < 0) {
perror("open");
return -1;
}
while ((p1 = fork()) == -1);
if (p1 == 0) {
for (i = 0; i < 500; i++) {
lockf(fd, F_LOCK, 0); // 加锁
printf("child%d\n", i);
lockf(fd, F_ULOCK, 0); // 解锁
}
} else {
while ((p2 = fork()) == -1);
if (p2 == 0) {
for (i = 0; i < 500; i++) {
lockf(fd, F_LOCK, 0); // 加锁
printf("son%d\n", i);
lockf(fd, F_ULOCK, 0); // 解锁
}
} else {
for (i = 0; i < 500; i++) {
lockf(fd, F_LOCK, 0); // 加锁
printf("daughter%d\n", i);
lockf(fd, F_ULOCK, 0); // 解锁
}
}
}
close(fd);
return 0;
}
在这个修改后的程序中,我们打开了一个输出文件,并在每个进程输出前调用lockf()函数给文件加锁。这样就可以保证输出的顺序是固定的,不会出现交错的情况。
阅读全文