关于shell脚本的应用上次已经对一些较基本的内容进行阐述,在此对shell脚本进行更进一步的了解--shell脚本的编程。
在讲述shell脚本的编程之前,先讲述一下关于编程语言的概念;
编程语言可分为高级语言,低级语言,机器语言;
区分的依据是离硬件的远近,效率高级语言是编程语言中最接近人类自然语言的一种语言,转化成计算机能够理解的机器语言的效率就低,而低级语言也就是汇编语言,作为较靠近机器语言的语言,转化成计算机能够理解的机器语言的效率就高;机器语言作为最接近计算机底层大量物理硬件的语言,为了能让用户在使用计算机的时候以非交互式的方式完成某些任务,需要将这些编制成一个文件,让计算机顺序读取,从而实现功能;人们利用高级语言,这种比较接近人类的自然语言编写代码,进行编译,转化成汇编语言,再由编译器转换成计算机能够理解的机器语言去访问在计算机最底层的大量的物理设备;用下面的路线可表示;
编程语言:
应用级语言->系统级语言->微码语言->机器语言
高级语言:
①根据源代码的处理方式分为:
编译运行语言:
根据高级语言写出的源代码,经过编译器编译成微码语言也就是汇编语言,汇编语言再 使用汇编器将汇编语言转化成二进制代码即机器语言,计算机再根据机器语言所表达的 内容,将代码转化成可以直接执行的二进制文件。
解释运行语言:
根据高级语言编写的源程序可以直接启动跟源代码对应的解释器程序,再由解释器一边 解释一边执行;
②根据其编程过程中的功能的实现是调用库还是调用外部程序文件:
完整编程语言:
利用库或编程组件进行编辑;
脚本编程语言:
解释器,shell脚本,调用shell程序其次调用需要的外部命令文件,命令解释器提供了 单一功能的编程接口,过程式编程逻辑的支持;
③根据程序的编写范式:程序=指令+数据
过程式编程语言:
以指令为中心,围绕指令(算法)的实现设计数据和数据结构,数据是要为指令服务 的;
对象式编程语言:
以数据为中心,将数据实例化为类,围绕着数据的需求来部署指令,类,属性(描述 某个类中的具体对象),方法;
Linux的shell编程作为一种高级程序设计语言,是个解释性语言,不需要编译它有变量,关键字和各种顺序,选择,循环的控制语句,如if,else,while,continue,break等语句,也支持函数模块,有自己的语法结构;
shell脚本的特点:
1.shell脚本的编写都需要在文本文档中编写,通过调用当前文本文档调用shell脚本;
2.shell脚本是以许多命令的组合,由各种控制语句结合;
3.“执行幂等性”--任何命令多次执行的结果是一样的
注意:很多命令都不具备“执行幂等性”,在shell脚本中就需要使用大量的程序逻辑来判断某个命令是否满足其运行条件,以避免在运行过程中出现严重错误;
在编写shell脚本的过程当中,第一行的绝对行首必须是解释器的路径即shebang,当前shell脚本的命令的运行需要在哪个解释器的解释下运行,解释器的解释需要逐条解释,解释执行一条命令后才能解释执行下一条命令;否则会出现解释错误,无法往下执行;解释器的路径为“#!”开头,而在shell脚本中“#”表示当前shell脚本的注释,注释必须放在当前行的绝对行首,shell脚本在运行时会忽略这样的内容;
例如:
#!/bin/bash(执行这个文件,并且用这个文件去解释在文本文档中所有的内容)
#!/bin/sh
#!/usr/bin/python
#!/usr/bin/perl
# hello(注释行)
怎样编写shell脚本的内容?
我们可以利用多种文本编辑器来编写shell脚本的内容
如vi,vim,nano,emacs,pico等;
在次推荐使用vim,vim作为vi的升级版本,功能更加齐全,比vi方便许多,更重要的是,vim在shell脚本编写的过程中可以使用高亮度的颜色标识脚本中的变量,关键字,控制结构的重要字符,可以在一定程度上检测shell脚本的正确度;
shell脚本的运行方法有:
①
直接运行shell脚本的路径:
例如
$./usr/men //这样可以直接运行在当前目录下的文本文件中的shell脚本内容
注意:在使用上述方式调用时,必须需为当前shell脚本赋予执行的权限;
如 chmod u+x 。/usr/men
②
以脚本名作为bash参数,其一般形式是:
$bash 脚本名 [参数]
其好处是一个shell脚本可以处理多种情况;
③将shell脚本的权限定义为可执行,将其加入到PATH的执行路径中,直接调用shell脚本名:
如果要把shell脚本名直接当命令使用,首先要为shell脚本名赋予执行权限,因为shell脚本文件都是文本文件,文本文件默认都不具备执行权限;
如
$chmod u+x ex2
然后将脚本所在的目录添加到命令搜索路径PATH中
$PATH=$PATH:./ex2
把当前工作目录以“.”表示,添加到命令搜索路径;这样就可以直接执行脚本文件名;
$ex2
shell脚本编写的重要结构:
多命令执行结构:
可以实现多条命令的结合,使多条命令共享资源;如“;”,“|”;冒号“;”可以将多条没有关联的命令联合在一起执行,而“|”管道线结构能使上一条命令的输出数据流,作为下一条命令的输入数据流,简单来说,“|”管道线的结构命令之间需要具有某种关联才可以实现;
如
#COMMAND|COMMAND...
#COMMAND;COMMAND...
在多命令执行结构中有这几种结构:
选择执行结构:判断是非正误,采用“&&”,“||”,“!”的形式;
逻辑运算:
与(AND):逻辑乘法&&,作为双目运算符;他放在两个逻辑表达式中间,仅当两个表达式 为真时,结果才为真;
状态返回值:0->success->true
1-255->fatlure->false
true&&true=true
true&&false=false
false&&true=false
false&&false=false
“与”的短路逻辑运算,只要第一个操作数为false,则其逻辑运算的结果一定位false
COMMAND1&&COMMAND2:如果第一个命令能成功执行,则第二个命令才有必要执行,如果 COMMAND1执行失败,则COMMAND2无法执行;
或(OR):逻辑加法||,作为双目运算符;他放在两个逻辑表达式中间,其中只有一个表 达式为真,结果就为真
true||true=true
true||false=true
false||true=true
false||false=false
只要第一个操作数为true则其逻辑运算的结果一定为真;
COMMAND1||COMMAND2(只要COMMAND1能够成功执行,后面的命令可以没必要执行,只 有当COMMAND1执行失败时,COMMAND2才会执行)
非(!):逻辑取反,!,作为单目运算符;他放在逻辑表达式之前,使原来为真的表达 式变为假,使原来为假的表达式变为真;
!string:读取命令历史空间的内容,在此“!”代表的意义与非无关;
! COMMAND:加空格,命令执行状态的取反
!COMMAND1&&COMMAND2:相当于COMMAND1||COMMAND2
如果COMMAND1成功执行则COMMAND2不需要执行;
如果COMMAND1不能成功执行则COMMAND2需要执行;
!COMMAND1||COMMAND2:相当于COMMAND1&&COMMAND2
如果COMMAND1成功执行则COMMAND2会被执行;
如果COMMAND1不能执行则COMMAND2不会被执行;
逻辑运算符优先级:
!>&&>||
异或:比对两个操作数的相同与否,如果不同则逻辑运算结果为真,如果相同则为假;双 目运算符;
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。