fork函数
在Linux系统中,fork函数是用于创建一个新的进程的函数。调用fork函数会创建一个新的进程。
fork函数的原型如下:
#include <unistd.h>
pid_t fork(void);
fork函数没有参数,返回值是一个pid_t类型的值。在成功创建新的进程后,fork函数会在父进程中返回子进程的PID,而在子进程中返回0。如果fork函数调用失败,则会返回-1。
它返回两个不同的值:
- 在父进程中,fork 返回新创建子进程的进程 ID (PID)。
- 在子进程中,fork 返回 0。
如果 fork 调用失败,则在父进程中返回 -1,并设置 errno 以指示错误原因。
调用fork函数后,父进程和子进程会有相同的代码、数据和堆栈。但是,父进程和子进程是两个独立的进程,它们有各自独立的地址空间。
以下是一个简单的示例代码:
#include <stdio.h>
#include <unistd.h>
int main() {
pid_t pid = fork();
if (pid < 0) {
// fork 失败
perror("fork failed");
return 1;
} else if (pid == 0) {
// 子进程
printf("子进程\n");
} else {
// 父进程
printf("父进程。 子进程的PID: %d\n", pid);
}
return 0;
}
1.创建子父进程,子进程将1.txt内容拷贝到2.txt中,父进程将3.txt内容拷贝到4.txt中。
#include <myhead.h>
int copy_child()
{
FILE *fp1,*fp2;
fp1=fopen("./3.txt","r");
if(fp1==NULL)
{
perror("fp1");
return -1;
}
fp2=fopen("./4.txt","w");
if(fp2==NULL)
{
perror("fp2");
return -1;
}
char buff[100];
printf("文本3内容:\n");
while(fgets(buff,sizeof(buff),fp1) !=NULL)
{
printf("%s",buff);
fputs(buff,fp2);
}
fclose(fp1);
fclose(fp2);
printf("\n");
printf("拷贝成功\n");
printf("\n");
printf("文本4内容\n");
char buff2[100];
fp2=fopen("./4.txt","r");
if(fp2==NULL)
{
perror("fp2");
return -1;
}
while(fgets(buff2,sizeof(buff),fp2) !=NULL)
{
printf("%s",buff2);
}
printf("\n");
fclose(fp2);
}
int copy_par()
{
FILE *fp1,*fp2;
fp1=fopen("./1.txt","r");
if(fp1==NULL)
{
perror("fp1");
return -1;
}
fp2=fopen("./2.txt","w");
if(fp2==NULL)
{
perror("fp2");
return -1;
}
char buff[100];
printf("文本1内容:\n");
while(fgets(buff,sizeof(buff),fp1) !=NULL)
{
printf("%s",buff);
fputs(buff,fp2);
}
fclose(fp1);
fclose(fp2);
printf("\n");
printf("拷贝成功\n");
printf("\n");
printf("文本2内容\n");
char buff2[100];
fp2=fopen("./2.txt","r");
if(fp2==NULL)
{
perror("fp2");
return -1;
}
while(fgets(buff2,sizeof(buff),fp2) !=NULL)
{
printf("%s",buff2);
}
printf("\n");
fclose(fp2);
}
int main(int argc, const char *argv[])
{
pid_t ID;
ID=fork();
int flag=0;
if(ID>0)
{
printf("父进程\n");
flag=1;
}
else if(ID==0)
{
printf("子进程\n");
flag=2;
}
else
{
perror("fork");
return -1;
}
if(flag==1)
{
copy_child();
}
else if(flag==2)
{
copy_par();
}
else
{
printf("拷贝失败\n");
return -1;
}
return 0;
}