进程创建:fork函数

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

  • 15
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值