shell函数的6个特点
最近系统的学习了一下shell的函数,总体感觉根其他语言的函数差不多,不过它也有自身的特点
一,调用函数必须在定义函数的后,不然会报错的
返回结果如下:
返回结果如下:
返回结果如下:
- fun
- fun (){
- echo "aaaaaa"
- }
- fun
- [root@krlcgcms01 mytest]# sh fun.sh
- fun.sh: line 1: fun: command not found //第一次调用fun是报错的,fun没有定义
- aaaaaa //第二次调用fum显示的结果
如果是php或者是JavaScript的话,就不会出现这样的问题
二,向shell函数传递参数很有特点
- fun2 (){
- echo $0 //$0本身文件名
- if [ $1 ] //参数为什么都是从$1开始呢,$0是本身文件名
- then
- echo "param1 is "$1
- else
- echo "param1 is null"
- fi
- if [ $2 ]
- then
- echo "param2 is "$2
- fi
- }
- fun2 aaa bbb //向fun2传2个参数
- fun2 ccc //向fun2传1个参数
- fun2 //不传参数
- [root@krlcgcms01 mytest]# sh fun2.sh
- pa.sh //第一次调用fun2,显示$0的值
- param1 is aaa
- param2 is bbb
- pa.sh //第二次调用fun2,显示$0的值
- param1 is ccc
- pa.sh //第三次调用fun2,显示$0的值
- param1 is null
这样的传参方式,很特别吧。
三,引用举例
- reference (){
- pa=\$"$1" //$1显示的是param
- echo $pa //显示的是$param
- x=`eval "expr $pa "` //x为test
- echo $1=$x //param=test
- local aaa=$x //定义局部变量
- bbb=$x //默认全局变量
- eval "$1='test been modified'"
- return 1 //最大返回整数257
- }
- param="test"
- echo $param " is test"
- reference param
- returnvalue=$? //返回值存放在$?里面
- echo "return value is " $return_value
- echo $param " is not test"
- returnvalue=$?
- echo "return value is " $return_value
- echo "aaa = "$aaa //局部变量外面不能调用
- echo "bbb = "$bbb
- [zhangy@localhost zhangy]$ sh re.sh
- test is test
- $param
- param=test
- return value is 1
- test been modified is not test
- return value is 0
- aaa =
- bbb = test
从上面的这个例子,我总结以下几点:
1,传引用也挺特别的,function max(&$num_a,$num_b){}如果方法体中$num_a改变了的话,调用的变量也会改变。shell引用的思想差不多,但是形势不一样。
2,shell函数的返回值,只能是整形,并且在0-257之间。
3,在方法定义的变量,如果没有做特别声明,一般都是局部变量,而shell正好相反,局部变量要特别声明。
4,调用方法和取得返回值之间,不能有任何操作,不然取不到return的值。
结合前二个例子显示的特点,差不多有6个特点,肯定还有其他的一些特性,待大家补充
shell循环,判断介绍,以及实例
shell的循环主要有3种,for,while,until
shell的分支判断主要有2种,if,case
一,for循环
- #!/bin/bash
- for file in $(ls /tmp/test/mytest |grep sh) //for in格式是shell for的基本格式,根js的for in类似
- do //循环开始你就把它当成{
- echo $file
- done //循环结束你就把它当成}
- for ((i=0;i<10;i++)) //注意是双小括号,由于受其他语言的影响,很容易搞错
- do
- echo -n $i
- done
- echo \ //输出换行
- for i in 0 1 2 3 4 5 6 7 8 9
- do
- echo -n $i
- done
- echo \
- for i in "0 1 2 3 4 5 6 7 8 9" //这个根上面是有区别的,这个循环只循环了一次,双引号里面只是一个变量
- do
- echo -n $i
- done
- exit 0
- #!/bin/bash
- i=0
- while ((i<10))
- do
- echo $i
- ((i += 1))
- done
- i=0
- while [ $i -lt 10 ] //注意括号内侧二边的空格
- do
- echo $i
- let "i+=1" //加1
- done
- exit 0
- #!/bin/bash
- END_CONDITION=end
- until [ "$var1" = "$END_CONDITION" ] //读取的变量根设定的变量相等时退出循环,不然永远循环
- do
- echo "Input variable #1 "
- echo "($END_CONDITION to exit)"
- read var1
- echo "variable #1 = $var1"
- echo
- done
- exit 0
- #!/bin/bash
- echo "Input a number #1 "
- read num
- echo "variable #1 = $num"
- if [ $num -lt 60 ] //注意lt前面的-,很容易忘的
- then
- echo "you are not pass"
- elif [ $num -lt 70 ] && [ $num -ge 60 ] //多个条件的判断
- then
- echo "pass"
- elif [[ $num -lt 85 && $num -ge 70 ]] //如果放在一起,要注意是双方括号,不要写成[ $num -lt 85 && $num -ge 70 ]
- then
- echo "good"
- elif (( $num <= 100 )) && (( $num >= 85 )) //对于有语言基础的人来说,这种写法让人觉得很舒服,不要忘了是双小括号
- then
- echo "very good"
- else
- echo "num is wrong"
- fi //if要有结束标签的,根XML很像,不闭合,就报错
- exit 0
- #!/bin/sh
- case $1 in
- start)
- echo "start ok"
- ;; //注意一点,要注意是双分号
- stop)
- echo "stop ok"
- ;;
- restart)
- echo "restart ok"
- ;;
- *)
- echo "no param"
- ;;
- esac //注意闭合标签
- exit 0
- [root@krlcgcms01 forif]# sh c1.sh stop
- stop ok