Linux--进程替换

1.什么是进程替换

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

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

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

图解:

2.如何发生进程替换

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

比如:

其中:

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

打印的结果为:

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

3.进程替换的结果

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

其他的exec*系列函数

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

相关推荐
JuiceFS19 小时前
从 MLPerf Storage v2.0 看 AI 训练中的存储性能与扩展能力
运维·后端
CYRUS_STUDIO1 天前
用 Frida 控制 Android 线程:kill 命令、挂起与恢复全解析
android·linux·逆向
熊猫李1 天前
rootfs-根文件系统详解
linux
chen9451 天前
mysql 3节点mgr集群部署
运维·后端
LH_R1 天前
OneTerm开源堡垒机实战(三):功能扩展与效率提升
运维·后端·安全
dessler1 天前
Hadoop HDFS-高可用集群部署
linux·运维·hdfs
泽泽爱旅行1 天前
awk 语法解析-前端学习
linux·前端
少妇的美梦2 天前
logstash教程
运维
chen9452 天前
k8s集群部署vector日志采集器
运维
chen9452 天前
aws ec2部署harbor,使用s3存储
运维