什么是进程程序替换:
用fork创建子进程后执行的是和父进程相同的程序(但有可能执行不同的代码分支),子进程往往要调用一种exec函数
以执行另一个程序。当进程调用一种exec函数时,该进程的用户空间代码和数据完全被新程序替换,从新程序的启动
例程开始执行。调用exec并不创建新进程,所以调用exec前后该进程的id并未改变。
单进程版-最简单的进程替换:
对应调用进程替换需要使用的函数:
最简单的进程替换:
对应的结果:
可以发现在调用完进程序替换以后,再不会执行main函数后面的代码。
关于这些函数的
-
如果这些函数调用成功则加载新的程序从启动代码开始执行,不返回,没有返回值
-
如果调用出错则返回-1
-
对应exec只有出错的返回值而成功没有返回值
多进程版,验证多种程序替换接口:
对应的:otherExe.cpp:
代码的结果:
可以发现没有affter进程,只有对应的等待成功。
同时再试试其他函数对应的接口的使用:
对应的5种方式都有了。
命名理解:
l(list) : 表示参数采用列表
v(vector) : 参数用数组
p(path) : 有p自动搜索环境变量PATH
e(env) : 表示自己维护环境变量
对应表格:更明了:
难道是只能放c++语言才能跑吗?
不是的,其他语言,包括python,java都可以跑
为什么都可以跑呢?
因为本质上他们都是进程
总结:
1.程序替换有没有创建新的进程?
没有,只进行进程的程序代码和数据的替换工作
2.环境变量是什么时候给进程的?
环境变量也是数据,在创建子进程的时候,环境变量已经被子进程继承下去了
所以,在程序替换中,环境变量不会被替换。
3.cpu如何得知程序的入口地址
linux中形成的可执行程序,是有格式的,ELF,可执行程序的标头,程序入口地址就存放在表头中
4.如果exec*能够执行系统命令,能不能执行我们自己的命令呢?
可以的
如果想给子进程传递环境变量如何传递?
1.新增环境变量:
使用putenv
代码:
执行结果:
2.彻底替换:
对应代码如下:
结果:
直接全部覆盖,之前操作系统中存在的都没有了。