Chinaunix首页 | 论坛 | 博客
  • 博客访问: 564673
  • 博文数量: 112
  • 博客积分: 5090
  • 博客等级: 大校
  • 技术积分: 1158
  • 用 户 组: 普通用户
  • 注册时间: 2005-08-19 22:21
文章分类

全部博文(112)

文章存档

2016年(1)

2015年(1)

2012年(1)

2011年(5)

2010年(7)

2009年(6)

2008年(18)

2007年(28)

2006年(16)

2005年(29)

我的朋友

分类: LINUX

2005-08-19 22:21:13

   使用Shell进行工作的人们对Unix/Linux下的Shell编程都很熟悉,在所有的Shell编程的书中都会提到#!/bin/bash,而这里到底包含了些什么?对操作系统而言,这一行字符串意味着什么?

转载--Linux解释器原理

引言
使用Shell进行工作的人们对Unix/Linux下的Shell编程都很熟悉,在所有的Shell编程的书中都会提到#!/bin/bash,而这里到底包含了些什么?对操作系统而言,这一行字符串意味着什么?你可能会说,不就是会让/bin/bash程序来解释这个脚本程序吗?当然你是对的,看看我们的标题,这里我们谈谈解释器,让我们一起来看看脚本文件里的第一句到底对系统而言意味着什么。但有一点我们可先明确一下,所谓解释器就是指#!行后面的可执行的程序。

一、我们从exec族函数谈起
如果你从不写C程序,可能需要对本节的内容看得更为仔细并且试验一下。

代码:

       #include

        extern char **environ;

        int execl(const char *path, const char *arg, ...);

       int execlp(const char *file, const char *arg, ...);

       int execle(const  char  *path,  const  char  *arg  , ..., char * const envp[]);

       int execv(const char *path, char *const argv[]);

       int execvp(const char *file, char *const argv[]);

 


exec
族函数一共有上面所列的5个,作用都是一样:执行一段新的代码。区别只是向函数传递的参数方式不同而已,我在这里讲讲execl函数:第一个参数 path是指向设置了执行位文件的路径,后面的可变参数列表分别指向了传递给此执行文件的参数列表(包括了参数0,即是执行文件的名称)。最后一个参数为 (char *) 0,表示参数列表结束。

对于解释器,exec族函数是这样做的(execl为例),如果path是指向了一个脚本,脚本的第一行以#!开头,则这样调用:
#!后面的字符串为命令,后面加上execl参数列表中指定的参数列表,这样形成了新的程序执行。
下面我们以例子来验证这个结果:

下面这个C程序的作用是回射所有命令行参数。

代码:

/* Program source : showargs.c *

 * Program name   : showargs   */

#include

 

int

main(int argc, char *argv[])

{

   int i;

   for(i = 0; i < argc; i++)

        {

           printf("arg[%d]: %s ", i, argv[i]);

        }

   return 0;

}

 

 


编译:gcc -o showargs showargs.c
执行:

代码:

$ pwd

/home/kiron

$ ./showargs arg1 arg2

arg[0]: ./showargs

arg[1]: arg1

arg[2]: arg2


我们在同一个目录下再写一个脚本
#!/home/kiron/showargs addargs
我没有打错,是的,这个脚本就只有一行,这个脚本我们命名为testexec,加上执行位后,执行情况如下:

代码:

$ ./testexec

arg[0]: /home/kiron/showargs

arg[1]: addargs

arg[2]: ./testexec

 


怎么会这样?我猜会有人对第2个参数./testexec不理解,暂且卖个关子,再引出一个C程序:

代码:

/* Program source : mytest.c *

 * Program name   : mytest   */

#include

 int

main(void)

{

  execl("/home/kiron/testexec", "testexec", "arg1", "arg2", (char *) 0);

  return 0;

}


编译:gcc -o mytest mytest.c
执行:

代码:

$ ./mytest

arg[0]: /home/kiron/showargs

arg[1]: addargs

arg[2]: /home/kiron/testexec

arg[3]: arg1

arg[4]: arg2

 



仔细观察上面的三个例子,答案开始浮出水面了。正如在开始时讲到的,exec族函数的处理是把#!后面的字符串为命令,后面加上execl参数列表中指定

阅读(994) | 评论(0) | 转发(0) |
0

上一篇:没有了

下一篇:计时函数的使用

给主人留下些什么吧!~~