linux-shell编程(一)

Shell 字符串

字符串是shell编程中最常用最有用的数据类型(除了数字和字符串,也没啥其它类型好用了),字符串可以用单引号,也可以用双引号,也可以不用引号

  • 单引号
str='this is a string'
单引号字符串的限制:
  1.单引号里的任何字符都会原样输出,单引号字符串中的变量是无效的
  2.单引号字串中不能出现单引号(对单引号使用转义符后也不行)
  • 双引号
your_name='qinjx'
str="Hello, I know you are \"$your_name\"! \n"
双引号的优点:
  1.双引号里可以有变量
  2.双引号里可以出现转义字符
  • 拼接字符串
your_name="qinjx"
greeting="hello, "$your_name" !"
greeting_1="hello, ${your_name} !"
echo $greeting $greeting_1
  • 获取字符串长度
string="abcd"
echo ${#string} #输出 4
  • 查找子字符串
    查找字符 "i 或 s" 的位置
string="runoob is a great company"
echo `expr index "$string" is`  # 输出 8

注意: 以上脚本中 "`" 是反引号,而不是单引号 "'",不要看错了哦。

Shell中 >/dev/null 2>&1

命令的结果可以通过%>的形式来定义输出(五部分的组合)

1:> 代表重定向到哪里,例如:echo "123" > /home/123.txt
2:/dev/null 代表空设备文件
3:2> 表示stderr标准错误
4:& 表示等同于的意思,2>&1,表示2的输出重定向等同于1
5:1 表示stdout标准输出,系统默认值是1,所以">/dev/null"等同于 "1>/dev/null"
(1) 1>/dev/null :首先表示标准输出重定向到空设备文件,也就是不输出任何信息到终端,说白了就是不显示任何信息。
(2) 2>&1 :接着,标准错误输出重定向 到 标准输出,因为之前标准输出已经重定向到了空设备文件,所以标准错误输出也重定向到空设备文件。

最常用的方式有: command > file 2>file 与command > file 2>&1
它们有什么不同的地方吗?
首先command > file 2>file 的意思是将命令所产生的标准输出信息,和错误的输出信息送到file 中.command > file 2>file 这样的写法,stdout和stderr都直接送到file中, file会被打开两次,这样stdout和stderr会互相覆盖,这样写相当使用了FD1和FD2两个同时去抢占file 的管道。
而command >file 2>&1 这条命令就将stdout直接送向file, stderr 继承了FD1管道后,再被送往file,此时,file 只被打开了一次,也只使用了一个管道FD1,它包括了stdout和stderr的内容。
从IO效率上,前一条命令的效率要比后面一条的命令效率要低,所以在编写shell脚本的时候,较多的时候我们会command > file 2>&1 这样的写法

例如 springboot执行jar时, nohup su $USER -c java -jar > /xx/xx.log 2>&1 &

Shell特殊变量 ($0 $? 等)
名称 解释
$0 脚本名称
$1-9 脚本执行时的参数1到参数9
$? 脚本的返回值
$# 脚本执行时,输入的参数的个数
$@ 输入的参数的具体内容(将输入的参数作为一个多个对象,即是所有参数的一个列表)
$* 输入的参数的具体内容(将输入的参数作为一个单词)
$@与$*的区别:
  $@与$*都可以使用一个变量来来表示所有的参数内容,但这两个变量之间有一些不同之处。
  $@:将输入的参数作为一个列表对象
  $*:将输入的参数作为一个单词

猜你喜欢

转载自blog.csdn.net/jishanwang/article/details/86063042