exec详解

jasenwan 2008-10-23 11:35:34
请问哪位大虾,能否告知此函数的使用范围及名词解释;
...全文
3583 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
老王 Robin 2012-11-01
  • 打赏
  • 举报
回复
学习学习学习学习学习学习学习
爱若一生 2012-04-12
  • 打赏
  • 举报
回复
每天回帖即可获得10分可用分!小技巧
wuliangyue7 2008-10-24
  • 打赏
  • 举报
回复
mark
  • 打赏
  • 举报
回复
mark一下……

天天用,没仔细研究过……

o(∩_∩)o...!~过段时间仔细研究研究
nicholas101 2008-10-24
  • 打赏
  • 举报
回复
学习了
lann64 2008-10-23
  • 打赏
  • 举报
回复
楼主得先说说是在什么环境下用。
exec好像不是c标准里的东西,不同系统下扩展和实现不太一样的。
lin_style 2008-10-23
  • 打赏
  • 举报
回复
http://lin-style.javaeye.com/blog/205951


楼主这是我对该函数的总结,通俗易懂。。可以看看

一开始我们会被他的种类繁多所迷惑,我到底该用哪个?每个的具体意义是什么?这里我将以宏观的角度想让大家有个意识上的认识:。。

文章以这种语言描述,如果感兴趣就看看吧。。
太乙 2008-10-23
  • 打赏
  • 举报
回复
看unix高级环境编程8.9 exec函数!
太乙 2008-10-23
  • 打赏
  • 举报
回复


execlp execl execle
| | |
| | |
|构造argv |构造argv |构造argv
| | |
| | |
\|/ \|/ \|/

execvp---试每一个path前缀----------->execv----------使用environ----------->execve(系统调用)








太乙 2008-10-23
  • 打赏
  • 举报
回复
对打开文件的处理与每个描述符的e x e c关闭标志值有关。见图3 - 1以及3 . 1 3 节中对
F D _ C L O E X E C的说明,进程中每个打开描述符都有一个e x e c关闭标志。若此标志设置,则在
执行e x e c时关闭该描述符,否则该描述符仍打开。除非特地用f c n t l设置了该标志,否则系统的
默认操作是在e x e c后仍保持这种描述符打开。
1 5 8 U N I X环境高级编程
下载
P O S I X . 1明确要求在e x e c时关闭打开目录流(见4 . 2 1节中所述的o p e n d i r函数)。这通常是由
o p e n d i r函数实现的,它调用f c n t l函数为对应于打开目录流的描述符设置e x e c关闭标志。
注意,在e x e c前后实际用户I D和实际组I D保持不变,而有效I D是否改变则取决于所执行程
序的文件的设置-用户- I D位和设置-组- I D位是否设置。如果新程序的设置-用户- I D位已设置,
则有效用户I D变成程序文件所有者的I D,否则有效用户I D不变。对组I D的处理方式与此相同。
在很多U N I X实现中,这六个函数中只有一个e x e c v e是内核的系统调用。另外五个只是库函
数,它们最终都要调用系统调用。这六个函数之间的关系示于图8 - 2中。在这种安排中,库函数
execlp 和execvp 使用PAT H环境变量查找第一个包含名为f i l e n a m e的可执行文件的路径名前缀。
图8-2 六个e x e c函数之间的关系
实例
程序8 - 8例示了e x e c函数。
程序8-8 exec函数实例
第8章进程控制1 5 9
下载
构造a rg v
试每一个
P A T H前缀
使用
e n v i r o n
构造a rg v 构造a rg v
e x e c v e(系统调用

太乙 2008-10-23
  • 打赏
  • 举报
回复
8.9 exec函数
8 . 3节曾提及用f o r k函数创建子进程后,子进程往往要调用一种e x e c函数以执行另一个程序。
当进程调用一种e x e c函数时,该进程完全由新程序代换,而新程序则从其m a i n函数开始执行。
因为调用e x e c并不创建新进程,所以前后的进程I D并未改变。e x e c只是用另一个新程序替换了
当前进程的正文、数据、堆和栈段。
有六种不同的e x e c函数可供使用,它们常常被统称为e x e c函数。这些e x e c函数都是U N I X进
程控制原语。用f o r k可以创建新进程,用e x e c可以执行新的程序。e x i t函数和两个w a i t函数处理
终止和等待终止。这些是我们需要的基本的进程控制原语。在后面各节中将使用这些原语构造
另外一些如p o p e n和s y s t e m之类的函数。
#include <unistd.h>
int execl(const charp a t* h n a m e, const char a* rg 0, ... /* (char *) 0 */);
int execv(const charp a t* h n a m e, char *consta rgv [] );
int execle(const charp a t* h n a m e, const char a* rg 0, ...
/* (char *)0, char *cones nt v p [] */);
int execve(const charp a t* h n a m e, char *consta rgv [], char *consten vp [] );
int execlp(const charf i l e* n a m e, const char a* rg 0, ... /* (char *) 0 */);
int execvp(const charf i l e* n a m e, char *consta rgv [] );
六个函数返回:若出错则为- 1,若成功则不返回
这些函数之间的第一个区别是前四个取路径名作为参数,后两个则取文件名作为参数。当
指定f i l e n a m e作为参数时:
1 5 6 U N I X环境高级编程
下载
• 如果f i l e n a m e中包含/,则就将其视为路径名。
• 否则就按PAT H环境变量,在有关目录中搜寻可执行文件。
PAT H变量包含了一张目录表(称为路径前缀),目录之间用冒号( : )分隔。例如下列n a m e = v a l u e
环境字符串:
P A T H = / b i n : / u s r / b i n : / u s r / l o c a l / b i n :.
指定在四个目录中进行搜索。(零长前缀也表示当前目录。在v a l u e的开始处可用:表示,在行
中间则要用::表示,在行尾以:表示。)
有很多出于安全性方面的考虑,要求在搜索路径中决不要包括当前目录。请
参见Garfinkel 和S p a fford [1991] 。
如果e x e c l p和e x e c v p中的任意一个使用路径前缀中的一个找到了一个可执行文件,但是该
文件不是由连接编辑程序产生的机器可执行代码文件,则就认为该文件是一个s h e l l脚本,于是
试着调用/ b i n / s h,并以该f i l e n a m e作为s h e l l的输入。
第二个区别与参数表的传递有关( l表示表( l i s t ),v表示矢量( v e c t o r ) )。函数e x e c l、e x e c l p和
e x e c l e要求将新程序的每个命令行参数都说明为一个单独的参数。这种参数表以空指针结尾。
对于另外三个函数( e x e c v, e x e c v p和e x e c v e ),则应先构造一个指向各参数的指针数组,然后将该
数组地址作为这三个函数的参数。
在使用ANSI C原型之前,对e x e c l , e x e c l e和e x e c l p三个函数表示命令行参数的一般方法是:
char * ar g0 , char *a rg 1, ..., char a* rg n, (char *) 0
应当特别指出的是:在最后一个命令行参数之后跟了一个空指针。如果用常数0来表示一个空
指针,则必须将它强制转换为一个字符指针,否则它将被解释为整型参数。如果一个整型数的
长度与char *的长度不同,e x e c函数实际参数就将出错。
最后一个区别与向新程序传递环境表相关。以e结尾的两个函数( e x e c l e和e x e c v e)
可以传递一个指向环境字符串指针数组的指针。其他四个函数则使用调用进程中的
e n v i r o n变量为新程序复制现存的环境。(回忆7 . 9节及表7 - 2中对环境字符串的讨论。其中
曾提及如果系统支持s e t e n v和p u t e n v这样的函数,则可更改当前环境和后面生成的子进
程的环境,但不能影响父进程的环境。)通常,一个进程允许将其环境传播给其子进程,
但有时也有这种情况,进程想要为子进程指定一个确定的环境。例如,在初始化一个新
登录的s h e l l时, l o g i n程序创建一个只定义少数几个变量的特殊环境,而在我们登录时,
可以通过s h e l l起动文件,将其他变量加到环境中。在使用ANSI C 原型之前, execle 的参
数是:
char * p a t h n a m e, char *a rg 0, ⋯, char *a rg n, (char *)0, chare n* v p[ ]
从中可见,最后一个参数是指向环境字符串的各字符指针构成的数组的指针。而在ANSI C原
型中,所有命令行参数,包括空指针, e n v p指针都用省略号(⋯)表示。
这六个e x e c函数的参数很难记忆。函数名中的字符会给我们一些帮助。字母p表示该函数
取f i l e n a m e作为参数,并且用PAT H环境变量寻找可执行文件。字母l表示该函数取一个参数表,
它与字母v互斥。v表示该函数取一个a rg v[ ]。最后,字母e表示该函数取e n v p[ ] 数组,而不使
用当前环境。表8 - 4显示了这六个函数之间的区别。
第8章进程控制1 5 7
下载
表8-4 六个e x e c函数之间的区别
函数p a t h n a m e f i l e n a m e 参数表a rg v[ ] e n v i r o n e n v p[ ]
e x e c l • • •
e x e c l p • • •
e x e c l e • • •
e x e c v • • •
e x e c v p • • •
e x e c v e • • •
(字母表示) p l v e
chlaws 2008-10-23
  • 打赏
  • 举报
回复
函数名: exec... 
//功 能: 装入并运行其它程序的函数
//用 法: int execl(char *pathname, char *arg0, arg1, ..., argn, NULL);
int execle(char *pathname, char *arg0, arg1, ..., argn, NULL,
char *envp[]);
int execlp(char *pathname, char *arg0, arg1, .., NULL);
int execple(char *pathname, char *arg0, arg1, ..., NULL,
char *envp[]);
int execv(char *pathname, char *argv[]);
int execve(char *pathname, char *argv[], char *envp[]);
int execvp(char *pathname, char *argv[]);
int execvpe(char *pathname, char *argv[], char *envp[]);
//程序例:

/* execv example */
#include <process.h>
#include <stdio.h>
#include <errno.h>

void main(int argc, char *argv[])
{
int i;

printf("Command line arguments:\n");
for (i=0; i<argc; i++)
printf("[%2d] : %s\n", i, argv[i]);

printf("About to exec child with arg1 arg2 ...\n");
execv("CHILD.EXE", argv);

perror("exec error");

exit(1);
}

69,337

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧