Linux C的多进程一直困扰着我,下面是自己写的多个实验以及实验中得出的结论。
- 子进程继承父进程的文件描述符表,文件指针指向同一个文件表项,所以拥有相同的偏移量,读写时不会造成顺序错乱。
#include<stdlib.h>
#include<unistd.h>
#include<fcntl.h>
#include<sys/wait.h>
/*
1.fork前打开文件
运行后,3个进程 一起 完成了一个文件的打印
*/
void myerror(char str[])
{
perror(str);
exit(1);
}
int main(int argc, char const *argv[])
{
if(argc < 2){
myerror("参数个数错误");
}
int fd = open(argv[1], O_RDONLY);
if(fd < 0)
myerror("文件打开失败");
int i;
for(i = 0; i < 3; i++){
int pid = fork();
if(pid < 0)
myerror("进程创建失败");
if(pid == 0)
break;
}
if(i < 3){
int ret;
char buf[10];
while((ret = read(fd, buf, 10)) != 0){
write(STDOUT_FILENO, buf, ret);
sleep(1);
}
}
else{
int ret;
do{
ret = waitpid(-1, NULL, 0);
}while(ret != -1);
}
close(fd);
return 0;
}
- 每个进程间拥有自己的文件描述符表,在进程中即使打开同一个文件,其文件指针也只会指向各自的文件表项,不会指向相同的文件表项。因此在读写文件时,每个进程的偏移量是不同,读写同一文件时,会造成顺序错乱。
关于这点也不难理解,因为进程之间相互独立,自然在各自进程中打开文件文件时不可能指向同一文件表项目。
#include<stdlib.h>
#include<unistd.h>
#include<fcntl.h>
#include<sys/wait.h>
/*
2.fprk后打开文件
运行后,3个进程 各自 完成了一个文件的打印
*/
void myerror(char str[])
{
perror(str);
exit(1);
}
int main(int argc, char const *argv[])
{
if(argc < 2){
myerror("参数个数错误");
}
int i;
for(i = 0; i < 3; i++){
int pid = fork();
if(pid < 0)
myerror("进程创建失败");
if(pid == 0)
break;
}
if(i < 3){
int fd = open(argv[1], O_RDONLY);
if(fd < 0)
myerror("文件打开失败");
int ret;
char buf[10];
while((ret = read(fd, buf, 10)) != 0){
write(STDOUT_FILENO, buf, ret);
sleep(1);
}
close(fd);
}
else{
int ret;
do{
ret = waitpid(-1, NULL, 0);
}while(ret != -1);
}
return 0;
}