Linux--进程替换

1.什么是进程替换

在fork函数之后,父子进程各自执行代码的一部分,但是如果子进程想要执行一份全新的程序呢?

通过进程替换来完成,进程替换就是父子进程代码发生写时拷贝,子进程执行自己的功能。

程序替换就是通过特定的接口,加载磁盘上的程序,替换子进程原有的程序,加载到调用进程的地址空间中。这就是进程替换!!!

图解:

2.如何发生进程替换

1.不创建子进程,直接调用系统接口:

比如:

其中:

execl(const char* path,const char* arg,.... ),以NULL结尾。path为找到路径,arg为指令,可以传入多个参数,最后一定要以NULL结尾。

打印的结果为:

所以:exec*系列函数执行的结果为替换原来的进程,执行成功后,会将原来的代码和数据进行替换,包括已经执行的和没有执行的。一旦调用成功,有序所有的代码都将不再执行。且exec*函数不需要返回值,不用进行函数返回值的判定。因为exec*函数在执行成功后,将原来所有的代码全部替换,包括它自己。

3.进程替换的结果

在加载新程序之前,父子进程一般为代码共享,数据写时拷贝,但有可能代码和数据同时发生写时拷贝。

其他的exec*系列函数

综上所述:l代表以列表形式展现,p表示以绝对路径,v代表数组的形式。

相关推荐
付出不多几秒前
linux——mysql高可用
linux·运维·mysql
L汐4 小时前
07 负载均衡
运维·nginx·负载均衡
pjx9874 小时前
服务间的“握手”:OpenFeign声明式调用与客户端负载均衡
java·运维·spring·负载均衡
牛奔4 小时前
Docker配置远程连接
运维·docker·云原生·容器·eureka
VR最前沿5 小时前
构建集成差异化灵巧手和先进机器人控制技术的自动化系统
运维·机器人·自动化
C-DHEnry5 小时前
Linux概述:从内核到开源生态
linux
蟑螂恶霸5 小时前
解决ubuntu20中tracker占用过多cpu,引起的风扇狂转
linux·运维·ubuntu
rzsh12346 小时前
[ linux-系统 ] 进程地址空间
linux
1024小神6 小时前
tauri2项目使用sidcar嵌入可执行文件并使用命令行调用
linux·运维·服务器
AI风老师6 小时前
2、ubuntu系统配置OpenSSH | 使用vscode或pycharm远程连接
linux·运维·服务器·ssh