Shell 指令码程式设计 是你在 Linux 下学习或练习程式设计的最简单的方式。尤其对 系统管理员要处理著自动化任务,且要开发新的简单的实用程式或工具等(这里只是仅举几例)更是必备技能。
本文中,我们将分享 10 个写出高效可靠的 bash 指令码的实用技巧,它们包括:
1 、 指令码中多写注释
这是不仅可应用于 shell 指令码程式中,也可用在其他所有型别的程式设计中的一种推荐做法。在指令码中作注释能帮你或别人翻阅你的指令码时了解指令码的不同部分所做的工作。
对于刚入门的人来说,注释用 # 号来定义。
# TecMint 是浏览各类 Linux 文章的最佳站点
2 、 当执行失败时使指令码退出
有时即使某些命令执行失败,bash 可能继续去执行指令码,这样就影响到指令码的其余部分(会最终导致逻辑错误)。用下面的行的方式在遇到命令失败时来退出指令码执行:
# 如果命令执行失败让指令码退出执行
set -o errexit
# 或
set -e
3 、 当 Bash 用未宣告变数时使指令码退出
Bash 也可能会使用能导致起逻辑错误的未宣告的变数。因此用下面行的方式去通知 bash 当它尝试去用一个未宣告变数时就退出指令码执行:
# 若有用未设定的变数即让指令码退出执行
set -o nounset
# 或
set -u
4 、 使用双引号来引用变数
当引用时(使用一个变数的值)用双引号有助于防止由于空格导致单词分割开和由于识别和扩充套件了万用字元而导致的不必要匹配。
看看下面的例子:
#!/bin/bash
# 若命令失败让指令码退出
set -o errexit
# 若未设定的变数被使用让指令码退出
set -o nounset
echo “Names without double quotes”
echo
names=”Tecmint FOSSMint Linusay”
for name in $names; do
echo “$name”
done
echo
echo “Names with double quotes”
echo
for name in “$names”; do
echo “$name”
done
exit 0
储存档案并退出,接著如下执行一下:
$ ./names.sh
在指令码中用双引号
5 、 在指令码中使用函式
除了非常小的指令码(只有几行程式码),总是记得用函式来使程式码模组化且使得指令码更可读和可重用。
写函式的语法如下所示:
function check_root(){
command1;
command2;
}
# 或
check_root(){
command1;
command2;
}
写成单行程式码时,每个命令后要用终止符号:
check_root(){ command1; command2; }
6 、 字串比较时用 = 而不是 ==
注意 == 是 = 的同义词,因此仅用个单 = 来做字串比较,例如:
value1=”tecmint.com”
value2=”fossmint.com”
if [ “$value1” = “$value2” ]
7 、 用 $(command) 而不是老旧的 `command` 来做代换
命令代换 是用这个命令的输出结果取代命令本身。用 $(command) 而不是引号 `command` 来做命令代换。
这种做法也是 shellcheck tool (可针对 shell 指令码显示警告和建议)所建议的。例如:
user=`echo “$UID”`
user=$(echo “$UID”)
8 、 用 readonly 来宣告静态变数
静态变数不会改变;它的值一旦在指令码中定义后不能被修改:
readonly passwd_file=”/etc/passwd”
readonly group_file=”/etc/group”
9 、 环境变数用大写字母命名,而自定义变数用小写
所有的 bash 环境变数用大写字母去命名,因此用小写字母来命名你的自定义变数以避免变数名冲突:
# 定义自定义变数用小写,而环境变数用大写
nikto_file=”$HOME/Downloads/nikto-master/program/nikto.pl”
perl “$nikto_file” -h “$1”
10 、 总是对长指令码进行除错
如果你在写有数千行程式码的 bash 指令码,排错可能变成噩梦。为了在指令码执行前易于修正一些错误,要进行一些除错。