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;
}