|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
用fork函数创建子进程后,子进程往往要调用一种exec函数以执行另一个程序,该子进程被新的程序替换,改变地址空间,进程映像和一些属性,但是pid号不变。3 X* ]6 L' P/ C+ o1 A
execve():% k, U6 T* L: e6 w U
#include
+ G1 y- d8 n5 yint execve(const char *filename, char *const argv[], char *const envp[]);% B( o7 N) @7 W' y8 B3 b) l# H" g
参数含义:
% d! J+ w" f7 [! ~# \filename:路径名,表示载入进程空间的新程序路径。
* Z0 t* n' o! q4 I& w, j1 n/ i6 Dargv[]:命令行参数,argv[0]为命令名。, A) O* M# X; B J
envp[]:新程序的环境变量。
9 M0 B2 q; Z, b返回值:成功时不会返回,使用时不用检查返回值,可通过errno检查。
* _" o- y9 H" P1 e) \+ Y! d以下函数都是根据execve实现:
. U( h: J7 H0 P8 |# nint execl(const char *path, const char arg, …/ (char *) NULL */);& b) k3 |7 Q: h
int execlp(const char *file, const char arg, …/ (char *) NULL */);" o- R1 L* v1 d% z4 b2 A
int execle(const char *path, const char arg, …/, (char *) NULL, char * const envp[] */);
# r( |' O; @+ I9 I0 Kint execv(const char *path, char *const argv[]); D5 V- D, r; k: r2 U- |6 v
int execvp(const char *file, char *const argv[]);
8 I2 S+ r2 ]& P8 @8 Qint execvpe(const char *file, char *const argv[],char *const envp[]);/ y9 [/ t8 g) ~+ E3 g5 w
实验代码:9 T( Z1 X. P( T* G
创建子进程,子进程使用execl调用ls查看当前目录下的文件。
/ z# s; H' {% O+ v) R. Lexec.c:
$ \. M# u/ i5 t( H+ G+ T使用execl调用shell命令查看文件信息。* U0 T1 }, x6 g0 E' ~
![]()
3 b% J# a5 o6 Q9 }- `( V ( v6 r+ J, Z6 X4 m) h
执行结果:! y* T, [ y, {8 ]9 L6 [
+ v; Y( r* d, v/ r2 K B( z6 C
Linux系统基于这些函数实现了“popen”,“system”等函数,这些函数能够直接调用shell等函数。+ P6 x. j2 k$ T% z/ Z3 g# v
$ Q6 [0 `% L9 W( a2 E% z
|
|