shell编程规范与变量

目录

Shell脚本概述

    Shell的作用

    Shell编程规范

    重定向与管道

Shell脚本变量

    自定义变量

    特殊变量

总结

 

Shell脚本概述

Shell脚本的概念

        将要执行的命令按顺序保存到一个文本文件

        给该文件可执行权限

        可结合各种Shell控制语句以完成更复杂的操作

Shell脚本应用场景

        重复性操作

        交互性任务

        批量事务处理

        服务运行状态监控

        定时任务执行

 

 

 

(1)Shell的作用

Shell的作用——命令解释器,“翻译官”

介于系统内核与用户之间,负责解释命令行

(2)Shell的作用

用户登录Shell

       登录后默认使用的Shell程序,一般为/bin/bash

       不同Shell的内部指令、运行环境有所区别

 

什么是shell

Shell是一个命令解释器,它在操作系统的最外层,负责直接与用户进行对话,把用户的输入解释给操作系统,并处理各种各样的操作系统的输出结果,输出到屏幕反馈给用户。这种对话方式可是交互也可以是非交互式的,我们所输入的命令计算机是不识别的,这时就需要一种程序来帮助我们进行翻译,变成计算机能识别的二进制程序,同时又把计算机生成的结果返回给我们。

 

shell的作用
Linux系统中的shell是一个特殊的应用程序,它介于操作系统内核与用户之间,充当了一个"命令解释器"的角色,负责接收用户输入的操作指令(命令)并进行解释,将需要执行的操作传递给内核执行,并输出执行结果。
常见的 shell 解释器程序有很多种,使用不同的shell
时,其内部指令、命令行提示符等方面会存在一些区别。通过/etc/shells

文件可以了解当前系统所支持的 shell脚本种类。

cat /etc/shells
/bin/sh#是bash命令的软链接(已经被/bin/bash所替换)

/bin/bash基准于GNU的框架下发展出的shell。
/usr/bin/sh己经被bash所替换。
/usr/bin/bash #centos和redhat系统默认使用bash shell
/bin/tcsh #csh的增强版,与csh完全兼容整合了csh,提供更多的功能。

/bin/csh#已经被/bin/bash所替换(整合C shell,提供更多的功能)

 

注:nologin:奇怪的shell,这个shell可以让用户无法登录主机。bash ( /bin/bash)是目前大多数Linux版本采用的默认shell。

 

为什么我们的系统上合法的shell要写入/etc/shells这个文件?

这是因为系统某些服务在运行过程中,会去检查用户能够使用的shells,而这些shell的查询就是借由/etc/shells这个文件。

 

用户什么时候可以取得shell来工作?还有我这个默认会取得哪一个shell?

当我登录的时候,系统就会给我shell让我来工作,而这个登录取得的shell就记录在/etc/passwd这个文件内。

 

不同的shell具备不同的功能,shell还决定了Linux中默认的shell是/bin/bash,流行的shell有ash、bash、ksh、csh、zsh等,不同的shell都有自己的特点以及用途

目前大多数linux系统默认使用的是bash

shell,默认登陆shell是/bin/bash,可以查看/etc/passwd文件里注明

这个shell是针对用户而言的,可以查看/etc/passwd里面的最后的字段使用的是哪个shell,如果想要修改可以用chmod -s或者chsh -s来重新指定

 

shell脚本是什么

shell脚本就是说我们把原来linux

命令或语句放在一个文件中,然后通过这个程序文件去执行时,我们就说这个程序为 shell脚本或shell

程序:我们可以在脚本中输入一系统的命令以及相关的语法语句组合,比如变量,流程控制语句等,把他们有机结合起来就形成了一个功能强大的 shell脚本

 

总结:将需要执行的命令保存到一个文件中,按照顺序执行,它不需要编译,它是解释型的

 

 shell脚本能干什么

自动化完成软件的安装部署,如安装部署LAMP架构服务

自动化完成系统的管理,如批量添加用户

自动化完成备份,如数据库定时备份

自动化的分析处理,如网站访问量

 

shell脚本使用场景

在需要完成大量复杂、重复性的工作时,不需要在命令行重复执行命令,直接运行shell脚本即可,大大的节省了时间提高了效率

 

如何学习shell脚本

熟悉掌握各种linux命令

掌握脚本的标准格式

掌握脚本的基本语法

 

shell脚本的构成

第一行为"#!/bin/bash”,脚本申明(默认解释器):表示此行以下的代码语句是通过/bin/bash程序来执行。还有其他类型的解释器,

比如#!/usr/ bin/python、#!/usr/bin/expect

注释信息:以"#“开头的语句表示为注释信息,被注释的语句在脚本运行时不会被执行

可执行语句:如echo命令,用于输出"“之间的字符串

 

编写第一个Shell脚本

编写脚本代码

       使用vim文本编辑器

       每行一条Linux命令,按执行顺序一次编写

vim test01.sh

cd / boot/

pwd

ls -lh vml*

 

例2

#!/ bin/ bash

#This is my first Shell-Script .

cd /boot

echo "当前的目录位于:"

pwd

echo "其中以vml开头的文件包括:"

ls -lh vml*

 

创建shell 程序的步骤:

第一步:创建一个包含命令和控制结构的文件。

第二步:修改这个文件的权限使它可以执行                #使用chmod +x test.sh

第三步:检测语法错误

第四步:执行./test01.sh

 

shell脚本执行

shell 脚本的执行通常有以下几种方式

方法一:当前路径(决定路径与相对路径)下执行脚本(要有执行权限)/ home/ first.sh 或者./first.sh

 

方法二:sh . bash脚本文件路劲(这种方式可以不对脚本文件添加执行权限)bash first.sh或sh first.sh

 

方法三: source脚本文件路劲(可以没有执行权限)source first.sh

 

方法四:其他方法

sh< first.sh或者cat first.sh lsh (bash)

 

重定向与管道操作

交换式硬件设备

        标准输入:从该设备接收用户输入的数据

        标准输出:通过该设备向用户输出数据

        标准错误:通过该设备报告执行出错信息

重定向:

用户通过操作系统处理信息的过程中,包括以下几类交互设备文件

标准输入(STDIN):默认的设备是键盘,文件编号为

0,命令将从标准输入文件中读取在执行过程中需要的输入数据。

标准输出(STDOUT):默认的设备是显示器,文件编号为

1,命令将执行后的输出结果发送到标准输出文件。

标准错误(STDERR):默认的设备是显示器,文件编号为

2,命令将执行期间的各种错误信息发送到标准错误文件。

从键盘接收用户输入的各种命令字串、辅助控制信息,并将命令结果输出到屏幕上;如果命令执行出错,也会将错误信息反馈到屏幕上

 

重定向输出

重定向输出指的是将命令的正常输出结果保存到指定的文件中,而不是直接显示在显示器的屏幕上。

重定向输出使用">"或">>"操作符号,分别用于覆盖或追加文件

若重定向输出的目标文件不存在,则会新建该文件,然后将前面命令的输出结果保存到该文件中;若目标文件已经存在,则将输出结果覆盖或追加到文件中。

>意思是当原来文件中有内容的话,原来的内容会被覆盖掉

>>意思是当原来文件中有内容的话,新加的内容会追加到里面而不会覆盖原来的内容

 

2)重定向输入

重定向输入指的是将命令中接收输入的途径由默认的键盘改为指定的文件,而不是等待从键盘输入。重定向输入使用“<"操作符。

通过重定向输入可以使一些交互式操作过程能够通过读取文件来完成。例如,使用 passwd命令为用户设置密码时,每次都必须根据提示输入两次密码字串,非常烦琐,若改

用重定向输入将可以省略交互式的过程,而自动完成密码设置(结合passwd

命令的"--stdin”选项来识别标准输入) 。

例1

#添加初始密码串内容"123456"”123456

vim pass.txt

 #从pass.txt读入密码给paswd命令而不是等待用户从键盘输入123456

passwd --stdin jerry <pass.txt

 

例2

[root@localhost ~]# cat 1.txt                  //以键盘为输入设备,这也是系统默认的

1234
1234

[root@localhost ~]# cat <1.txt                //跟cat 1.txt结果是一样的,但是这是以1.txt文件作为输入设备了

1234
1234
默认情况下, cat
命令会接受标准输入设备(键盘)的输入,并显示到控制台,但如果用文件代替键盘作为输入设备,那么该命令会以指定的文件作为输入设备,并将文件中的内容读取并显示到控制台
[ root@localhost ~]#cat <<0
//以o作为分界符,只要不输入0就会一直输入数据从而显示到屏幕

> 123
>456

>0

123

456
[root@localhost ~]#cat << 0 > a.txt
//可以把输入重定向和输出重定向结合使用,把从屏幕输出的内容保存到文件

>123
>456

> 0
[root@localhost ~]# cat a.txt

123
456

 

错误重定向

错误重定向指的是将执行命令过程中出现的错误信息(如选项或参数错误等)保存到指定的文件,而不是直接显示在屏幕上。错误重定向使用"2>"操作符

 

2个作用:

在实际应用中,错误重定向可用来收集程序执行的错误信息,为排错提供依据

还可以将无关紧要的错误信息重定向到空文件/dev/null 中,以保持脚本输出的简洁

 

使用"2>"操作符时,会像使用">"操作符一样覆盖目标文件的内容,若要追加内容而不是覆盖文件,则应改用"2>>"操作符

 

当命令输出的结果可能既包括标准输出(正常执行)信息,又包括错误输出信息时,可以使用操作符">""2>"将两类输出信息分别保存到不同的文件,也可以使用"&>"操作符将两类输出信息保存到同一个文件

 

/ dev/null:把它看作"黑洞",所有写入它的内容都会永远丢失

而尝试从它那儿读取内容则什么也读不到.然而/dev/null对命令行和脚本都非常的有用

echo kgc > / dev / null

cat / dev / null #什么信息也看不到

 

&>和>&符号

&表示等同于的意思

例1:把正确和错误的消息输入到相同的位置

1>&2把标准输出重定向到标准错误

2>&1把标准错误重定向到标准输出,

 

ls /tmp xxxx >1.txt 2>&1

或:

ls / tmp xxxx 2>2.txt 1>&2

 

例1:将错误显示的内容和正确显示的内容分开

ls /etc/passwd xxxx

ls:无法访问   xxx:没有那个文件或目录

/ etc/passwd

ls letc/passwd xxx > a.txt

ls:无法访问xxx: 没有那个文件或目录

cat a.txt

/etc/passwd

ls letc/passwd xxx2> a.txt/ etc/passwd

cat a.txt

ls:无法访问xxx:没有那个文件或目录

注:使用2>操作符时,会像使用>

一样覆盖目标文件的内容,若追加而不覆盖文件的内容即可使用2>>操作符

 

列2

tar jcf / nonedir/etc.tgz letc/ 2> error.log

cat /error. log

 

例3,在编译源码包的自动化脚本中,若要忽略make、make install等操作过程信息,则可以将其定向到空文件/dev/null。

 

#!/ bin/ bash #自动编译安装httpd 服务器的脚本

cd /usr/ src/httpd-2.4.25/

./ configure --prefix=/usr/local/httpd --enable-so &> /dev/nullmake &> / dev/ null

make install &> /dev/null #/dev/null等同于make install > /dev/null 2>&1

 

 

管道操作

管道(pipe)操作为不同命令之间的协同工作提供了一种机制,位于管道符号""左侧的命令输出的结果,将作为右侧命令的输入(处理对象),同一行命令中可以使用多个管道。

在 shell 脚本应用中,管道操作通常用来过滤所需要的关键信息。

$bash $表示系统提示符,$表示此用户为普通用户,超级用户的提示符是#,

bash是shell的一种,是linux下最常用的一种shell

$bash的意思是执行一个子shell,此子shell为bash。

 

 列1:

rpm -qa l grep httpd

grep "/bin/bash$" /etc/passwd | awk -F: '{print $1,$7}'

 

列2

df -hT l grep "/$"l awk '{ print $6}'

 

总结:

重定向与管道操作是shell

环境中十分常用的功能,若能够熟练掌握并灵活运用,将有助于编写代码简洁但功能强大的shell脚本程序

 

 

Shell变量的作用、类型

变量的作用

用来存放系统和用户需要使用的特定参数(值)

变量名:使用固定的名称,由系统预设或用户定义

变量值:能够根据用户设置、系统环境的变化而

变化变量的类型

自定义变量:由用户自己定义、修改和使用

特殊变量:环境变量,只读变量,位置变量,预定义变量

自定义变量

1、变量的定义

Bash中的变量操作相对比较简单,不像其他高级编程语言(如c/C++、Java等)那么复杂。在定义一个新的变量时,一般不需要提前进行声明,而是直接指定变量名称并赋给初始值(内容)即可

 

格式:变量名=变量值

变量名:临时存放数据的地方

变量值:临时的可变化的数据

 

等号两边没有空格。变量名称需以字母或下划线开头,名称中不要包含特殊字符(如+、-、*、/、.、 ?、%、&、#等)

 

用echo查看和引用变量的值

通过在变量名称前添加前导符号"$”,可以引用一个变量的值,使用echo

命令可以查看变量,可以在一条echo命令中同时查看多个变量值

 

Product=Python

version=2.7.13

echo $Product$version

 

当变量名称容易和紧跟其后的其他字符相混淆时,需要添加大括号"{}"将其括起来,否则将无法确定正确的变量名称。对于未定义的变量,将显示为空值

举例说明

 

列2

{}引用变量

echo $ { Product}2.5

echo ${test } RMB

 

 

 

echo选项

echo -n表示不换行输出

使用echo -e输出转义字符,将转义后的内容输出到屏幕上

常用的转义字符如下:

\c 不换行输出,在"\c"后面不存在字符的情况下,作用相当于echo -n

\n 换行

\t 转义后表示插入tab,即制表符

 

注: \转义符,跟在\之后的特殊符号将失去特殊含义,变为普通字符。如\s将输出""s符号,而不当做是变量引用

 

例1

[root@localhost ~].echo -n hellohello

[ root@localhost ~]#

 

例2

[ rootelocalhost ~]#echo -e "hello\t“

hello

 

例3转义符案列例:

echo $VAR1

echo \$VAR1

$VAR1

 

unset(取消变量名)

特殊操作

还有一些特殊的赋值操作,可以更灵活地为变量赋值,以便适用于各种复杂的管理任务

 

双引号(")

双引号主要起界定字符串的作用,特别是当要赋值的内容中包含空格时,必须以双引号括起来:其他情况下双引号通常可以省略

1、当内容中有空格

echo "hello world"

echo nihao

2、当以变量的值进行赋值

[root@localhost ~]# version=2

[root@localhost ~]#pyver="python $version"

[root@localhost ~]# echo $pyver

python 2

 

单引号( ')

当要赋值的内容中包含$、"、\等具有特殊含义的字符时,应使用单引号括起来。

在单引号的范围内,将无法引用其他变量的值,任何字符均作为普通字符看待。输入什么就显示什么

但赋值内容中包含单引号(`)时,需使用\符号进行转义,以免冲突。

[ root@localhost ~]# test=123

[ root@localhost ~]# echo "$test"

123

[ root@localhost ~]# echo ' $test'

$test

 

反撇号( `)

反撤号主要用于命令替换,允许将执行某个命令的屏幕输出结果赋值给变量。

反撇号括起来的范围内必须是能够执行的命令行,否则将会出错

 

ls -lh `which useradd`

先通过 which useradd 命令查找出 useradd 命令的程序位置,然后根据查找结果列出文件属性

date +%Y-%m-%d

[root@localhost ~]. time= `date +%T`

[ root@localhost ~]. echo $time

04:23:22

使用反撤号难以在一行命令中实现嵌套命令替换操作,这时可以改用"$()"来代替反撇号操作,以解决嵌套的问题

rpm -qc $ (rpm -qf s (which useradd) )

 

交互式定义变量

read 命令

除了上述赋值操作以外,还可以使用 Bash 的内置命令read来给变量赋值。

用来提示用户输入信息,从而实现简单的交互过程。执行时将从标准输入设备(键盘)读入一行内容,并以空格为分隔符,将读入的各字段依次赋值给指定的变量(多余的内容赋值给最后一个变量)。若指定的变量只有一个,则将整行内容赋值给此变量。

[root@localhost ~]# read test
99999999                   //等待用户输入,把输入的值赋予test变量

[root@localhost ~]# echo $test
99999999

一般来说为了使交互式操作的界面更加友好,提高易用性,read命令可以结合"-p"选项来设置提示信息,以便告知用户应该输入什么内容等相关事项

[root@localhost ~]# read -p "请输入你的姓名:" name
请输入你的姓名:zly
[root@localhost ~]# echo $name
zly

 

交互式定义变量( read)

-p提示用户的信息

-n定义字符数

-s不显示用户输入的内容,常用于输入密码read -s -p "input your password:" pass

-t定义超时时间,超过多长时间没输自动退出

 

从文件读取内容赋值给变量

[root@localhost ky17]# echo 192.168.147.4 > ip.txt
[root@localhost ky17]# cat ip.txt
192.168.147.4
[root@localhost ky17]# read -p "IP 地址:" IP < ip.txt
[root@localhost ky17]# echo $IP
192.168.147.4

 

stty -echo//关闭屏幕回显

stty echo//开启屏幕回显

 

变量的作用范围

默认情况下,新定义的变量只在当前的 shell环境中有效,因此称为局部变量,当进入子程序或新的子shell环境时,局部变量将无法再使用

[root@localhost ~] # bash                #进入子shell环境

[root@localhost ky17]# exit             #退出

 

export命令

为了使用户定义的变量在所有的子shell环境中能够继续使用,减少重复设置工作,可以通过内部命令export将指定的变量导出为全局变量。用户可以同时指定多个变量名称作为参数(无须使用"s"符号),变量名之间以空格分隔

[root@localhost ky17]# export name IP                      #导出为全局变量


[root@localhost ky17]# echo $name $IP
zly 192.168.147.4
[root@localhost ky17]# bash
[root@localhost ky17]# echo $name $IP                    #子程序引用全局变量

 

使用export导出全局变量的同时,也可以为变量进行赋值,这样在新定义全局变量时就不需要提前进行赋值了

env查看用户当前环境变量

export ABC=123

再次env就能看到了

export -n ABC取消定义的全局变量变成局部变量

 

数值变量的运算及特殊变量

 

在 Bash shell环境中,只能进行简单的整数运算,不支持小数运算

整数值的运算主要通过内部命令expr进行

运算符与变量之间必须有至少一个空格。

 

运算内容:加(+)、减(-)、乘(*)、除(/)、取余(%)

运算符号:s(())和$[ ]

运算命令: expr和let

运算工具: bc (系统自带)

 

expr命令(不仅可以运算,还支持输出到屏幕)

常用的几种运算符如下所述。

+:加法运算。

-:减法运算。

\*:乘法运算,注意不能仅使用"*"符号,否则将被当成文件通配符。

/:除法运算。

%:求模运算,又称为取余运算,用来计算数值相除后的余数。

 

[root@localhost ky17]# a=10
[root@localhost ky17]# b=20

[root@localhost ky17]# sum=`expr $a \* $b \* 2`
[root@localhost ky17]# echo $sum
400

[root@localhost ky17]# vim xiao.sh

chmod +x xiao.sh

./xiao.sh

 

$[ ]和$ (( ))必须要和echo在一起用因为他只能运算无法输出结果

[root@localhost ky17]# echo $((5 - 2))
3
[root@localhost ky17]# echo $[5 + 3]
8

[root@localhost ky17]# x=10
[root@localhost ky17]# y=10
[root@localhost ky17]# echo $[x+y]
20
[root@localhost ky17]# echo $((x+y))
20

 

let的运算可以改变变量本身的值,但不显示结果,需要echo,其他的运算方式可以做运算但不改变变量本身的值

[root@server myscripts]# n=1; let n=n+1;echo $n

2

[rooteserver myscripts]# let n+=2             // n=n+2

[ rooteserver myscriptsi# echo $n

4

[root@server myscripts]# let n=n**2        //求幂,4的2次方

[ rooteserver myscripts]#echo $n

16

[rooteserver myscripts]#let n++               //n自加1

[ rooteserver myscripts]# let n--                //n自减1

[ rooteclient opt]# echo $a

13

[rooteclient opt]# echo $ [a++]         //先输出再自增1,这时a的值已经变于

13

[rooteclient opt]#echo $a

14

[rooteclient opt]# echo $[++a]           //先自增1再输出,所以直接输出了变化后的值

15

[ rooteclient opt]# echo $a

15

 

使用bc进行运算,支持小数运算,但在脚本中不可直接使用否则会进入交互界面,可以用echo结合管道使用

 

[root@localhost ky17]# echo "scale=4;10/3" |bc
3.3333
[root@localhost ky17]# echo "3^2" |bc
9
[root@localhost ky17]# a=10
[root@localhost ky17]# b=3
[root@localhost ky17]# echo "scale=10;$a/$b" | bc
3.3333333333

 

bc还可以做逻辑运算,真为1,假为0

 

常用的运算表达式

[root@localhost ky17]# i=$(expr 12 \* 5)
[root@localhost ky17]# echo $i
60
[root@localhost ky17]# i=$((12*5))
[root@localhost ky17]# echo $i
60
[root@localhost ky17]# i=$[18*5]
[root@localhost ky17]# echo $i
90
[root@localhost ky17]# let i=16*5
[root@localhost ky17]# echo $i
80

 

i++相当于i=$[$i+1]

i--相当于i=$[$i-1]

i+=2相当于i=$[$i+2]

 

特殊变量

环境变量

环境变量指的是出于运行需要而由Linux

系统提前创建的一类变量,主要用于设置用户的工作环境,包括用户宿主目录、命令查找路径、用户当前目录、登录终端等。

环境变量的值由 Linux系统自动维护,会随着用户状态的改变而改变。

使用env命令可以查看到当前工作环境下的环境变量,对于常见的一些环境变量应了解其各自的用途。例如,变量USER表示用户名称,HOME 表示用户的宿主目录,LANG表示语言和字符集,PWD 表示当前所在的工作目录,PATH

表示命令搜索路径等、RANDOM表示随机数,会返回0-32767的整数,USER表示当前账户的账户名称等,一般都用全大写定义,注意和自定义变量区分

[root@localhost ~]# vim /etc/profile      #永久生效编辑文件
[root@localhost ~]# echo $UID
0
[root@localhost ~]# echo $SHELL
/bin/bash
[root@localhost ~]# echo $LANG
zh_CN.UTF-8
[root@localhost ~]# echo $RANDOM
11548

 

PATH变量用于设置可执行程序的默认搜索路径,当仅指定文件名称来执行命令序时,Linux系统将在 PATH变量指定的目录范围查找对应的可执行文件,如果找不到则会提示"command not found"。

方法一:将脚本的目录加入$PATH

[root@localhost ~]# PATH="$PATH: /root"       //这时临时的,如果永久生效需要编辑/etc/profile文件

[root@localhost ~]#echo $PATH

/usr/local/sbin :/usr/locai/bin:/usr/sbin:/usr/bin:/ root/bin:/root

[rootelocalhost ~].test.sh

hello world

方法二:将你自己写的脚本放到$PATH中的某一个目录

 

在 Linux系统中,环境变量的全局配置文件为/etc/profile,在此文件中定义的变量作用于所有用户。

除此之外,每个用户还有自己的独立配置文件(~/.bash_profile)。

修改完了要重新登陆才能生效,如果想立即生效,可以使用source

 

注意:修改$PATH需要慎重操作,如果找不到了会影响命令的使用!!!

例如:

[rootelocalhost ~]#PATH=            //手误将PATH设为空

[rootelocalhost ~]#echo $PATH

[rootelocalhost ~]#ls

-bash: ls:没有那个文件或目录

 

只读变量

shell 变量中有一种特殊情况,一经设定,其值是不可改变的,这种变量被称为只读变量。

在创建变量的时候可将其设置为只读属性,也可以将已存在的变量设置为只读属性,只读变量主要用于变量值不允许被修改的情况

只读变量不可以改变值也不可以被删除

[ root@localhost ~]# test=123

[root@localhost ~]# readonly test

#readonly用来定义只读变量,一旦使用readonly定义的变量在脚本中就不能更改

[root@localhost ~]# echo $test

123

[root@localhost ~]# test=456

-bash: test:只读变量

[root@localhost ~]# unset test

-bash : unset: test:无法反设定:只读variable

需要退出登陆

 

位置变量

当执行命令行操作时,第一个字段表示命令名或脚本程序名,其余的字符串参数按照从左到右的顺序依次赋值给位置变量。

位置变量也称为位置参数,使用$1、$2、$3、...、$9表示

命令或脚本本身的名称使用“$0表示

[root@localhost ky17]# vim user.sh
[root@localhost ky17]# chmod +x user.sh
[root@localhost ky17]# sh user.sh lisi 123456

 

[root@localhost ky17]# vim num.sh
[root@localhost ky17]# ./num.sh 10 20
10 + 20 = 30

 

 

预定义变量

预定义变量是由 Bash 程序预先定义好的一类特殊变量,用户只能使用预定义变量,而

不能创建新的预定义变量,也不能直接为预定义变量赋值。预定义变量使用"s"符号和另一个符号组合表示

$#:表示命令行中位碰参数的个数。

$*:表示所有位置参数的内容,这些内容当做一个整体

$@:表示列出所有位置参数,但是是以单个的形式的列出

$?:表示前一条命令执行后的返回状态,返回值为0表示执行正确,返回任何非0值均表示执行出现异常。

$0:表示当前执行的脚本或程序的名称

$$:表示返回当前进程的进程号

$ !:返回最后一个后台进程的进程号

 

总结

Shell的作用与应用场景

Shell脚本的编写规范与执行方法

重定向与管道的作用与使用方法

自定义变量赋值是单引号、双引号、反撇号的使用方法

数值变量的常用运算符:+、-、\*、/、%

环境变量、只读变量、位置变量、预定义变量的用途

posted @   请叫喵总  阅读(67)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek “源神”启动!「GitHub 热点速览」
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 2 本地部署DeepSeek模型构建本地知识库+联网搜索详细步骤
点击右上角即可分享
微信分享提示