fork拷贝

1. 完成拷贝那题

#include <stdio.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>

int main(int argc, const char *argv[])
{
	pid_t pid=fork();	
	int fd_f=open("./011.png",O_RDWR);
	int fd_cpy=open("./12.png",O_RDWR|O_CREAT,0664);
	int f=lseek(fd_f,0,SEEK_END);
	char buf=0;
	ssize_t count=0;
	if(pid>0)
	{
		lseek(fd_f,0,SEEK_SET);
		lseek(fd_cpy,0,SEEK_SET);
		if(count<(f/2))
		{
			while(1)
			{
				buf=0;
				ssize_t res=read(fd_f,&buf,1);
				if(res==0)
				{
					printf("上半部分完成\n");
					break;
				}
				write(fd_cpy,&buf,res);
				count+=res;
			}
		}
		wait(NULL);
	}
	else if(pid==0)
	{
		lseek(fd_f,f/2,SEEK_SET);
		lseek(fd_cpy,f/2,SEEK_SET);
		if(count<f/2)
		{
			while(1)
			{
				buf=0;
				ssize_t res_w=read(fd_f,&buf,1);
				if(res_w==0)
				{
					printf("下半部分完成\n");
					break;
				}
				write(fd_cpy,&buf,res_w);
				count+=res_w;
			}
		}
	}
	else
	{
		return -1;
	}
	close(fd_f);
	close(fd_cpy);
	return 0;
}


2. 验证运行到waitpid非阻塞形式时,若子进程没退出,则子进程会不会变成僵尸进程

不会。


3. 创建孤儿进程和僵尸进程

孤儿进程

#include <stdio.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, const char *argv[])
{
	pid_t pid=fork();
	if(pid>0)
	{
		int i=0;
		while(i<3)
		{
			sleep(1);
			printf("父进程\n");
			i++;
		}
		exit(1);
	}
	else if(pid==0)
	{
		while(1)
		{
			sleep(1);
			printf("子进程\n");
		}
	}
	else
	{
		return -1;
	}

	return 0;
}

僵尸进程

#include <stdio.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>


int main(int argc, const char *argv[])
{
	pid_t pid=fork();
	if(pid>0)
	{
	
		while(1)
		{
			sleep(1);
			printf("父进程\n");
		
		}
	}
	else if(pid==0)
	{
		int i=0;
		while(i<3)
		{
			sleep(1);
			printf("子进程\n");
			i++;
		}
	}
	else
	{
		return -1;
	}
	return 0;
}

05-16
### Fork 的概念及其在编程和版本控制中的应用 #### 编程中的 Fork `fork()` 是 Unix 和类 Unix 操作系统中用于创建新进程的一个重要函数。调用 `fork()` 函数时,当前进程会复制自己并生成一个新的子进程[^1]。这个过程可以被描述为:父进程通过调用 `fork()` 创建了一个几乎完全相同的副本——即子进程。父子进程之间的主要区别在于它们的 PID(Process ID),以及返回值的不同。 - **返回值** - 对于父进程而言,`fork()` 返回的是子进程的 PID。 - 子进程中,`fork()` 则返回 0。 - 如果发生错误,则返回 `-1` 表示失败。 下面是一个简单的 C 代码示例展示如何使用 `fork()`: ```c #include <stdio.h> #include <unistd.h> int main() { pid_t pid = fork(); // 调用 fork() if (pid == 0) { printf("Child Process: My PID is %d\n", getpid()); } else if (pid > 0){ printf("Parent Process: Child's PID is %d\n", pid); } else { perror("Fork failed"); } return 0; } ``` 此程序展示了基本的父子进程关系,并打印各自的 PID 值来区分两者。 需要注意的是,在某些硬件环境下实现高效内存分配存在困难的情况下,标准 POSIX 定义还提供了像 `vfork()` 这样的替代方案作为补充选项之一[^3]。 #### 版本控制系统中的 Fork 另一方面,“fork”一词也广泛应用于软件开发领域特别是基于 Git 或其他分布式版本控制系统的工作流程里。“Forking repository”指的是开发者从原始仓库派生出自己的独立分支来进行修改或者实验而不影响原项目[^2]。这种做法常见于开源协作模式下当个人希望提交补丁给上游维护者之前先在一个分离的空间完成初步工作后再发起 pull request 请求合并更改到官方主线之中去。 例如,在 GitHub 平台上执行如下操作即可轻松获得一份属于您自己的远程拷贝以便自由编辑而无需担心破坏源码库结构: 1. 访问目标存储库页面; 2. 单击右上方 “Fork” 按钮; 3. 自动跳转至您的账户下的克隆版地址链接处; 之后就可以按照常规方式 clone 下载下来本地继续后续处理步骤啦! 总结起来看,无论是操作系统层面还是现代互联网服务架构设计思路当中都离不开对资源隔离机制的研究探讨,而这其中就包含了我们今天所提到这两个不同维度却同样重要的技术知识点:“fork”。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值