遇到的一个关于IFS的问题

        machine=`hostname`
        process=`cat trace_$$.out | grep Trace | cut -d "-" -f 1 | sort | uniq`
        str=(${process[@]})
        len=${#str[*]}

        if [ "$len" -ne 0 ];then
                log info "Warning: Some traces are opened, see as blow table!"
        fi

        title=`echo -e  " Number  \tProcess  \t\tMachine"`
        format=`echo -e "-------  \t-------  \t\t-------"`
        for((i=0;i<$len;i++))
        do
                result[$i]=`printf  " %d \t\t%s \t\t%s\n" $i ${str[$i]} $machine`
        done

        oldIFS=$IFS
        IFS=$'\n'
        log info "$title\n $format\n ${result[*]}"
        IFS=$oldIFS

outout:

Number         Process                 Machine
 -------                -------                         -------
  0             GDMI                                IHATCA26-0-0-1
 1              GLOAD                             IHATCA26-0-0-1
 2              SUP                                 IHATCA26-0-0-1
 3              TSMSTUB                      IHATCA26-0-0-1


转:

不得不说shell里面的全局变量都是些恶心的家伙,特别是这家伙----IFS,恶心之极,差点被它忽悠过去了,所以赶快记录下来,以免下次再被忽悠!!!
STRING1="111 222 333 444"
echo $STRING1
echo "$STRING1"
这组代码没什么好说的,输出的是:111 222 333 444,它的作用是和下面那段做对比!!
STRING2="111 222  333   444"
echo $STRING2
echo "$STRING2"
输出的结果是
111 222 333 444
111 222  333   444
为什么?? 第一个输出的结果明显不对,难道输出了的是STRING1的值,明显不可能,这就是IFS的鬼伎俩。。。
首先介绍一下这个家伙,IFS是shell内定的一个变量,默认定义的值为 <space> <tab> <newline>3个,不好意思,这3个值我打出来也看不见,只能写英文。那IFS的作用是什么了,它的作用就是把字符串里的某某字符(和 它一样的字符,例如上面的<space> <tab> <newline>)转义成分隔符
例如"111 222  333   444",这个字符串其实就是 111<space>222<space><space>333<space><space><space>444, 由于IFS里也有个<space>,所以在它眼中<space>就是分隔符,所以"111 222  333   444"在它看来就是这个鬼样子111<分隔符>222<分隔符><分隔符>333<分隔符>< 分隔符><分隔符>444,由于分隔符(不是所有的分隔符都会合并,空格是个例外)进行合并,所以就成了111<分隔 符>222<分隔符>333<分隔符>444,而这该死的<分隔符>偏偏显示出来和一个空格是一样的(或者说 空格被用来表示分隔符),所以显示出来就变成了"111 222 333 444"怎么样? 郁闷吧
所以 echo $STRING2 显示出来的是"111 222 333 444",echo "$STRING2"之所以还是保持原样是因为""它屏蔽了IFS的功能,才未遭其迫害!!
如果我这样改下,结果就一样了,这时候shell就不会认为空格是分隔符了,倒是&符号要倒霉了 呵呵。。。
IFS='&'
STRING2="111 222  333   444"
echo $STRING2
echo "$STRING2"
另外还有个$*的全局变量,它和IFS狼狈为奸,尽干坏事,今天也揭下老底!!
$*指的是脚本入口参数的字符串集,说也说不清楚,举个例子
你在终端输入一个脚本,带了3个参数,这样
./script 111 222 333
那么 echo $*输出的就是111 222 333,这没什么问题,但是下面的东西就又忽悠人了
首先是这段代码
IFS='&'
STRING2="111&222&&333&&&444"
echo $STRING2
echo "$STRING2"
这输出的是
111  222  333   444
111&222&&333&&&444
经过上面的解释,这个忽悠不到人-----因为IFS='&',所以字符串里的&全成了分隔符,所以第一个输出的是111 222 333 444,后面还有一组代码
现在终端运行./script 111 222  333   444
IFS='&'
echo $*
echo "$*"
输出的是
111 222 333 444
111&222&333&444
我来解释一下是为什么
因为$*等于111IFS222IFS333IFS444,亦等于111&222&333&444,由于echo $*时,&代表分隔符,所以要转换成空格 ,而第二行由于""的作用使得&没有进行转换


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值