シェル関数、関数パラメーターの受け渡し、関数スコープ、再帰、ライブラリの作成
1つはシェル機能
コマンドのシーケンスを1つの形式で一緒に記述します
コマンドシーケンスの再利用が簡単
1.1シェル関数の定義
function 函数名 {
命令序列
}
函数名 () {
命令序列
}
function db1 {
read -p "请输入: " value
return $[$value*2] return表示退出函数并返回一个退出值
}
db1 调用这个函数(调用函数必写的)
echo $? 查看退出值,不写这步不会显示结果
db1 () {
read -p "请输入: " value
echo $[$value * 2]
}
result=`db1`
echo $result
関数の戻り値:returnは、関数を終了して終了値を返すことを意味します。これは、スクリプトの$?変数で表示できます。
1.2使用の原則
1. $?変数は最後に実行されたコマンドの終了ステータスコードのみを返すため、関数が終了したらすぐに戻り値を取得します
2.終了ステータスコードは0〜255である必要があり、値がそれを超えると256で除算されます。
2、関数パラメータの転送
sum1 () {
sum=$[$1 + $2]
echo $sum
}
read -p "输入第一个参数: " first
read -p "输入第二个参数: " second
sum1 $first $second
sum2 () {
sum=$[$1 + $2]
echo $sum
}
sum2 $1 $2
-----------------
abc.sh xxx xxx
3、関数変数の範囲
シェルスクリプトの関数は、現在のシェル環境でのみ有効です
シェルスクリプトの変数はデフォルトでグローバルです
ローカルコマンドを使用して、変数を関数に制限します
myfun () {
local i 设置局部变量
i=8
echo $i
}
------------------------------
i=9 全局环境
myfun
echo $i
#!/bin/bash
abc () {
local i 设置局部变量
i=8
echo $i
}
-----------------------------
i=9 全局环境
abc
echo $i
4、再帰
関数は独自の関数を呼び出します
要因
fact () {
if [$1-eq 1 ]
then
echo 1
else
local temp=$[$1-1]
local result=$ (fact $temp) 这里是一个新的函数,初始值是$temp,所以下面一步的$1变成了$temp
echo $[$1 * $result] 这里变化的一直是$1,$result始终为1
# 5 * $result (4*$result (3*$result (2*$result (1) )))
fi
}
read -p "请输入: " n
result=$ (fact $n)
echo $result
n=5
fact 5 fact 4 fact 3 fact 2 fact 1
$1=5 4 3 2 1
5つの再帰ディレクトリ
function list_files () {
for f in 'ls $1'
do
if [-d "$1/$f" ] 判断$1下的$f是不是目录
then
echo "$2$f" 是目录就输出这个目录,空格是为了好区分父子目录
list_files "$1/$f" " s2" 然后在在$1/$f($1/$f在这里已经变成了$1)这一层目录下再判断$f($f是一个新的赋值)是不是目录
else
echo "$2$f" 不是目录就输出$f结果
fi
done
}
list_files "/var/log" ""
6、ライブラリを作成します
vim myfuncs.sh
jiafa () {
echo $[$1 + $2]
}
chengfa () {
echo $[$1 * $2]
}
chufa () {
if [$2 -ne 0];then
echo $[$1 / $2]
else
echo "$2不能为0"
fi
}
vim test.sh
. myfuncs.sh
value1=10
value2=5
result1=`jiafa $value1 $value2`
result2=`chengfa $value1 $value2`
result3=`chufa $value1 $value2`
echo "加法结果为: $result1"
echo "乘法结果为: $result2"
echo "除法结果为: $result3"