linux之shell编程基本语法

Posted 暴躁IT老绵羊---著有:《深入理解Flink核心设计与实践

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux之shell编程基本语法相关的知识,希望对你有一定的参考价值。

  Shell是用户与内核进行交互操作的一种接口,目前最流行的Shell称为bash Shell。Shell也是一门编程语言<解释型的编程语言>,即shell脚本<就是在用linux的shell命令编程>。一个系统可以存在多个shell,可以通过cat /etc/shells命令查看系统中安装的shell,不同的shell可能支持的命令语法是不相同的。

 

原文和作者一起讨论:http://www.cnblogs.com/intsmaze/p/6681562.html

微信:intsmaze

 

基本格式

  代码写在普通文本文件中,通常以 .sh为后缀名

vi intsmaze.sh

#!/bin/bash    ## 表示用哪一种shell解析器来解析执行我们的这个脚本程序
echo "hello world"   ##  注释也可以写在这里
## 这是一行注释

执行脚本

sh intsmaze.sh

或给脚本添加x权限,直接执行,否则只能通过sh xxx.sh执行

chmod 755 intsmaze.sh

./intsmaze.sh

基本语法

系统变量

Linux Shell中的变量分为“系统变量”和“用户自定义变量”。可以通过set命令查看系统变量。

[hadoop@centos-Reall-131 shtest]$ set
BASH=/bin/bash
HADOOP_HOME=/home/hadoop/hadoop-2.6.4
HISTCONTROL=ignoredups
HISTFILE=/home/hadoop/.bash_history
HISTFILESIZE=1000
HISTSIZE=1000
HOME=/home/hadoop
HOSTNAME=centos-Reall-131
HOSTTYPE=i386
ID=500
JAVA_HOME=/home/hadoop/app/jdk1.7.0_65
LANG=en_US.UTF-8
LESSOPEN=\'|/usr/bin/lesspipe.sh %s\'
LINES=24
LOGNAME=hadoop

访问系统变量:$HOME、$PWD、$SHELL、$JAVA_HOME等等

自定义变量

  1、语法

  变量=值 (例如STR=abc)

  等号两侧不能有空格

  使用变量: $arg

   双引号和单引号有区别:双引号仅将字符串中的空格脱意;单引号会将字符串中的变量引用比如$param脱意。

  2、示例

[hadoop@centos-Reall-131 ~]$ STR=hello world 
-bash: world: command not found
[hadoop@centos-Reall-131 ~]$ STR="hello world" [hadoop@centos-Reall-131 ~]$ A=9 [hadoop@centos-Reall-131 ~]$ echo $A 9 [hadoop@centos-Reall-131 ~]$ echo $STR hello world

如果想打印 hello worlds is greater  怎么办?

echo $STRs is greate 行吗?

不行,正确写法是:

echo ${STR}s is greate

[hadoop@centos-Reall-131 ~]$ echo ${STR}s is greate
hello worlds is greate
[hadoop@centos-Reall-131 ~]$ echo \'${STR}s is greate\'
${STR}s is greate
[hadoop@centos-Reall-131 ~]$ echo "please$STR"
pleasehello world
[hadoop@centos-Reall-131 ~]$ echo \'please$STR\'
please$STR

unset A 撤销变量 A

readonly B=2 声明静态的变量 B=2,不能 unset

export  A   #可把变量提升为当前shell进程中的全局环境变量,可供其他子shell程序使用

 vi a.sh

#!/bin/bash
a="a in a.sh"
echo $a
/root/scripts/b.sh

vi b.sh

#!/bin/bash
b="b in b.sh"
echo $b
echo $a

然后执行  ./a.sh ,会发现b脚本中并没有把a脚本中定义的a变量打印出来。

如果要在b中打印出a脚本的变量a,需要在a脚本中把变量a做export定义,此时,a变量就成了a.sh脚本所在bash进程的全局变量,该进程的所有子进程都能访问到变量a。

另一种方式:

如果在a.sh脚本中用如下方式调用b.sh

.  ./b.sh    ## 注意:重点关注最前面那个 “.”号

或者

source ./b.sh   ##

则,b.sh就在a.sh所在的bash进程空间中运行,而不是在a进程中的子进程中运行了。

总结:

1、a.sh中直接调用b.sh,会让b.sh在a所在的bash进程的“子进程”空间中执行

2、而子进程空间只能访问父进程中用export定义的变量

3、一个shell进程无法将自己定义的变量提升到父进程空间中去

4、“.”号执行脚本时,会让脚本在调用者所在的shell进程空间中执行

3、反引号赋值

A=`ls -la`    ## 反引号,运行里面的命令,并把结果返回给变量A

A=$(ls -la)   ## 等价于反引号

4、特殊变量

$? 表示上一个命令退出的状态码

$$ 表示当前进程编号

$0 表示当前脚本名称

$n 表示n位置的输入参数(n代表数字,n>=1)

$# 表示参数的个数,常用于循环

$*和$@ 都表示参数列表

注:$*与$@区别

$* 和 $@ 都表示传递给函数或脚本的所有参数

ü 不被双引号" "包含时——

$* 和 $@ 都以$1  $2  … $n 的形式组成参数列表

ü 当它们被双引号" "包含时——

"$*" 会将所有的参数作为一个整体,以"$1 $2 … $n"的形式组成一个整串;

"$@" 会将各个参数分开,以"$1" "$2" … "$n" 的形式组成一个参数列表

 

以上是关于linux之shell编程基本语法的主要内容,如果未能解决你的问题,请参考以下文章

Linux Shell编程之基本概念

Linux之Shell编程(13)

linux——shell编程之函数和循环控制

Linux之Shell编程(13)--Shell文件包含

Linux之Shell编程(13)--Shell文件包含

Shell之基本用法