运行Linux程序有三种方法:

(1)、使文件具有可执行权限,直接运行文件。

(2)、直接调用命令解释器执行程序(Linux shell是一种解释型语言)。

(3)、使用source执行文件

第一种:作为可执行程序

其中第三中运行方式和前两种有所不同。下面我们来看一个程序小栗子,文件名:echo.sh

#! /bin/sh
cd tmp
echo "hello world"

这是一个完成的,可执行的Linux Shell程序。下面我们来运行这个程序来看看运行结果:

[root@iZ280zyxdy3Z shTest]# pwd                       # 查看当前工作目录
/home/jason/shTest #返回当前工作目录
[root@iZ280zyxdy3Z shTest]# chmod +x echo.sh #将echo.sh文件权限变为可执行
[root@iZ280zyxdy3Z shTest]# ./echo.sh #运行echo.sh文件
hello world #返回的运行结果
[root@iZ280zyxdy3Z shTest]# pwd
/home/jason/shTest #工作目录没有发生改变
[root@iZ280zyxdy3Z shTest]#

从上面的输出你会看到程序运行了。下面我们来看看这个文件的内容吧,首先是第一行#! /bin/sh

当命令行执行程序的时候,首先判断程序是否有可执行权限。如果没有足够的权限,机器会告诉用户:“权限不够”。从安全的角度考虑我们也能够了解到,任何程序在机器上运行,首先应该是判断执行这个程序的用户是否有这个权限。在上面三种运行程序的方式中,我们直接执行文件需要文件具有可执行权限。

其中chmod命令可以修改文件权限,+x参数使可执行文件具有可执行权限。命令行shell接收到我们的执行命令,并且判定我们有可执行权限后,则调用Linux内核命令新建(fork)一个进程。在新建的进程中调用我们的命令。如果这个命令式编译型的(二进制文件),则Linux内核知道怎么去执行文件。可是我们的echo.sh是一个文件文件,而不是二进制文件(编译型的文件)内核并不知道如何运行。内核不知道怎么运行的,但是shell却知道这确实是一个脚本文件,于是shell会启动一个新的shell进程来执行这个程序。由于现在的Linux中用于好几个shell,到底这个程序该选择那个shell呢,这时候#! /bin/sh发挥作用的时候到了,他指定了 shell会创建一个什么样的进程来执行脚本。在本例中我们创建了一个/bin/sh(标准shell)进程来执行脚本。他的执行过程是命令行在扫过第一行,发现#! 之后读取他后面的字符,搜索解释器的完整路径。如果这一行有参数的话也会一起读取。这个程序的运行首先经过第一种判断,如果不是直接可以运行的文件,则会查看是不是第二种运行方式(通过调用命令行解释器),刚好echo.sh文件就是可以通过命令行解释器可以运行。也就是在这三种执行方法中,如果#! 中指定的shell解释器和第二种指定的shell解释器相同的话,这两种的执行结果就是相同的。

如果你不知道具体的解释器的路径,可以通过whereis查询:
$>whereis bash
/bin/bash

2、作为解释器参数

这种运行方式是,直接运行解释器,其参数就是 shell 脚本的文件名,如:

[root@localhost test]# /bin/sh test1.sh
test11 for shell!!!

这种方式运行的脚本,不需要在第一行指定解释器信息,写了也没用。

3、使用source执行文件

下面来看看通过第三种方式来执行程序:

[root@iZ280zyxdy3Z shTest]# pwd                   #查看当前工作目录
/home/jason/shTest
[root@iZ280zyxdy3Z shTest]# source echo.sh #运行echo.sh文件
hello world
[root@iZ280zyxdy3Z tmp]# pwd
/tmp #工作目录改变了
[root@iZ280zyxdy3Z tmp]#

工作目录怎么改变了呢??下面我们来看下是什么原因:

在解决上面问题之前,先让我们来看看shell的命令种类:

Linux Shell可执行的命令有三种:内建命令,shell函数和外部命令

(1))、内建命令就是shell程序本身包含的命令。这些命令集成在shell解释器里面,例如几乎所有的shell命令解释器中都包含cd内建命令来改变工作目录。部分内建命令的存在是为了改变shell本身的属性设置,在执行内建命令的时候没有进程的创建与消亡。另一部分常见的内建命令就是常用的I/O命令,例如:echo

(2)、Shell函数是一系列程序代码,是shell语言写成。它可以像以他命令一样被引用。

(3)、外部命令是独立于shell的可执行程序。例如find,grep,echo.sh。命令行shell在执行外部命令的时候,会创建一个当前shell的复制进程来执行。在执行过程中存在进程的创建与消亡。

外部命令的执行过程如下:

参考如下:http://www.cnblogs.com/stephen-liu74/archive/2011/12/20/2285454.html

shell编程入门(一)的更多相关文章

  1. Linux Shell编程入门

    从程序员的角度来看, Shell本身是一种用C语言编写的程序,从用户的角度来看,Shell是用户与Linux操作系统沟通的桥梁.用户既可以输入命令执行,又可以利用 Shell脚本编程,完成更加复杂的操 ...

  2. 转:Linux Shell编程入门

    http://www.cnblogs.com/suyang/archive/2008/05/18/1201990.html 从程序员的角度来看, Shell本身是一种用C语言编写的程序,从用户的角度来 ...

  3. 转inux Shell编程入门

    http://www.cnblogs.com/suyang/archive/2008/05/18/1201990.html 从程序员的角度来看, Shell本身是一种用C语言编写的程序,从用户的角度来 ...

  4. Linux下的shell编程入门

    通常情况下,我们从命令行输入命令每输入一次就能够得到系统的一次响应.一旦需要我们一个接着一个的输入命令而最后才得到结果的时候,这样的做法显然就没有效率.要达到这样的目的,通常我们利用shell程序或者 ...

  5. Shell编程入门基础上

    前言 为什么学 Shell Shell 脚本语言是实现 Linux/UNIX 系统管理及自动化运维所必备的重要工具, Linux/UNIX 系统的底层及基础应用软件的核心大都涉及 Shell 脚本的内 ...

  6. [转]Linux Shell编程入门

    转自:http://www.cnblogs.com/suyang/archive/2008/05/18/1201990.html 从程序员的角度来看, Shell本身是一种用C语言编写的程序,从用户的 ...

  7. SHELL编程入门简介

    一.SHELL软件概念和应用场景 1) 学习Linux技术,不是为了学习系统安装.命令操作.用户权限.配置IP.网络管理,学习Linux技术重点:基于Linux系统部署和维护各种应用软件.程序(Apa ...

  8. shell编程入门

    背景知识 Shell 是用户与内核进行交互操作的一种接口,是 Linux 最重要的软件之一.目前最流行的 Shell 称为 bash Shell,bash Shell 脚本编程以其简洁.高效而著称,多 ...

  9. Linux简介及常用命令使用5--linux shell编程入门

    生成 测试数据的shell脚本 Vim data_create.sh rm -rf ./data.txttouch data.txtfor((i=0;i<2000;i++))dostr=',na ...

  10. Shell编程入门(再版)(在)

    简单的演示样本Shell规划 演示样例1. #!/bin/bash #This is to show what a shell script looks like echo "Our fir ...

随机推荐

  1. struts.xml文件中package元素的各大属性讲解

    Struts2中的包: Struts2使用包来组织Action,将Action放在包下来定义,通过package元素配置一个包,通过package的子元素action来定义一个Action: Stru ...

  2. scala VS python2 (linux or shell)

    PS:只考虑最新版的scala和python2.x,由于python3.x和python2.x区别比较大,而且主流的一些开源项目都用的python2,目前python2一点点在兼容python3 1. ...

  3. Python学习笔记二:函数式编程

    1:Python中,内置函数名相当于一个变量,指向内置函数.所以可以通过函数名调用相应函数,也可以给函数名赋值,改变它的内容,如:可以把另一个函数变量赋值给它,那它就指向了所赋值的函数了. 2:高级函 ...

  4. H5移动端JS操作LocalStorage方法

    LocalStorage和SessionStorage LocalStorage 是对Cookie的优化 没有时间限制的数据存储 在隐私模式下不可读取 大小限制在500万字符左右,各个浏览器不一致 在 ...

  5. Flash 加密和破解

    关于Flash(swf),我们需要明确一点: ***Flash字节码的意义都是公开的 所以如果cracker真的有足够的耐心他最终还是可以破解掉你的Flash.我们能做的只是尽量提高Flash被破解的 ...

  6. cocos2d-js 在线更新代码脚本 动态更新脚本程序 热更新 绕过平台审核 不需重新上架

    2014年8月15日补充 cocos2d-js 3.0 rc0 的AssetsManager有缺陷,有一些注意点:(可以阅读源代码发现) 1.旧manifest中有,但新manifest中没有的文件( ...

  7. .NET Core 全新认识

    来源:yubinfeng cnblogs.com/yubinfeng/p/6626694.html 一.概述      .NET 经历14年,在Windows平台上的表现已经相当优秀,但是“跨平台.开 ...

  8. PRM路径规划算法

    路径规划作为机器人完成各种任务的基础,一直是研究的热点.研究人员提出了许多规划方法:如人工势场法.单元分解法.随机路标图(PRM)法.快速搜索树(RRT)法等.传统的人工势场.单元分解法需要对空间中的 ...

  9. python之获取微信access_token

    # -*- coding: cp936 -*- #python 27 #xiaodeng #获取微信access_token #办法一:将该url直接填写到浏览器地址中可以获得access_token ...

  10. SSM:spring+springmvc+mybatis框架中的XML配置文件功能详细解释(转)

    原文:https://blog.csdn.net/yijiemamin/article/details/51156189# 这几天一直在整合SSM框架,虽然网上有很多已经整合好的,但是对于里面的配置文 ...