您的位置:首页 > 运维架构 > Shell

awk-语法深入-用户自定义函数

2016-08-22 20:02 281 查看
 - 自定义函数格式

   awk 自定义函数获取参数,选择性的返回标量值,函数可以在程序的顶层任意位置定义。自定义格式为:

  function name(arg1,arg2,....argn){

      statement(s)

  }



  在自定义的函数中,指定的参数被当作局部变量,他们会隐藏任何同名的全局性变量。

调用函数的格式:

 function(expr1,expr2,...) # 忽略任何返回值

 result=function(expr1,expr2,...) # 将返回值存储在变量中


 自定义函数时,所有位于函数体内部且未出现在函数参数列表中的变量,awk都将视之为全局变量。

  awk允许调用函数时,被调用函数中的参数比它定义时所声明的参数还少,这样额外的参数(既没有被传递值的参数)被视为局部变量,对于这类变量,一般将它列在自定义的函数的参数列表,并且字首前置一些空白。这个额外的参数通常初始化为空字符串.

eg.

 funchtion add(x,y  sum)   // sum 就是一个局部变量,初始化为空字符串

{

    sum=x+y

    return sum            /

}

a=add(1,2)                // 传递的参数少于函数add()定义时的数量

printf("m: %d\n",a)


- 值传递和地址传递(引用传递):

   值传递是将变量的值传给了函数的形参,变量本身并未改变,还是原来的值。

   地址传递是将变量的地址传递给了函数的形参,被调用函数会通过变量的地址找到变量被定义的地方,进而对变量作出改动,与变量的值改变。

awk不支持取址操作,因此awk中普通变量为值传递,awk的数组则默认为地址传递。

- 递归调用 

  awk函数支持自己调用自己。

  应用场景: 某些不断执行相同逻辑的的程序.

 eg. 求斐波那契数列(Fibonacci sequence)的某一项

fibonacci.awk

 function fibonacci(nth)

 {

     if(nth == 1 || nth == 2) 

        return 1

     else

        return  fibonacci(nth-1) + fibonacci(nth-2)  // 递归

 }

######执行体###########################

 {

    n=$1  // 第一个字段

    printf(" %dth of fibonacci sequence is: %d\n", n, fibonacci(n))

 }  

问题: 复杂度大,求第n项时需要把前n-1项都计算一遍!


解决:使用数组,把所有求过的项保存起来,再求新的项时,直接调用。

总结: print 与 printf 的区别:

  print 输出的内容后会自动换行

  printf 不会自动换行,需要添加'\n';还可以自定义输出格式.

[root@web1 function]# echo -e "1\n2\n34\n43\n23" |awk '{print "Number is: " $1}'

Number is: 1

Number is: 2

Number is: 34

Number is: 43

Number is: 23

[root@web1 function]# echo -e "1\n2\n34\n43\n23" |awk '{printf "Number is: " $1;} END{printf "\n"}'

Number is: 1Number is: 2Number is: 34Number is: 43Number is: 23

[root@web1 function]# echo -e "1\n2\n34\n43\n23" |awk '{printf "Number is: " $1 "\n"}'

Number is: 1

Number is: 2

Number is: 34

Number is: 43

Number is: 23
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  awk awk shell