在linux中,使用shell动态生成数组的方法,以及seq的一些使用技巧。 下面以一个求和计算的题目为例进行分析。
题目:请用linux shell 写一段脚本,实现从1..1000中所有偶数的和值。
复制代码代码示例:
start=1;
[toy@centos5 ~]$ start=1;total=0;while [ $start -le 1000 ];do [[ $(($start%2)) == 0 ]]&&total=$(($total+$start)); start=$(($start+1));done;echo $total; 运行结果:249500,在linux shell 中,”;”作为命令行分隔符。如果大家对于$(()) 运算符号不是很理解,可以查看:linux shell 实现 四则运算(整数及浮点) 简单方法 ,如果对于:[[]] [] 符号,可以参考另外一篇文章linux shell 逻辑运算符、逻辑表达式详解。
方法二:
复制代码代码示例:
start=0;
total=0; for i in $(seq $start 2 1000); do total=$(($total+$i)); done; echo $total; [toy@centos5 ~]$ start=0;total=0;for i in $(seq $start 2 1000); do total=$(($total+$i));done;echo $total; 250500 上面语句已经代码方面明显优于方法一,而且性能方面表现也很好。 下面比较即可发现:
比较性能:
复制代码代码示例:
[toy@centos5 ~]$ time (start=0;total=0;for i in $(seq $start 2 1000); do total=$(($total+$i));done;echo $total;) 250500
real 0m0.016s user 0m0.012s sys 0m0.003s [toy@centos5 ~]$ time (start=1;total=0;while [ $start -le 1000 ];do [[ $(($start%2)) == 0 ]]&&total=$(($total+$start)); start=$(($start+1));done;echo $total;) 250500 real 0m0.073s user 0m0.069s sys 0m0.004s 方法一耗时 是方法二的 6倍!
seq 使用:
复制代码代码示例:
seq [OPTION]... LAST
seq [OPTION]... FIRST LAST seq [OPTION]... FIRST INCREMENT LAST [toy@centos5 ~]$ seq 1000 ‘起始默认是 1,间隔默认也是1 [toy@centos5 ~]$seq 2 1000 ‘间隔默认是1 [toy@centos5 ~]$seq 1 3 10 '从1开始,到10 间隔为3 结果是:1 4 7 10
说明:默认间隔是“空格” 如果想换成其它的可以带参数:-s
复制代码代码示例:
[toy@centos5 ~]$seq -s'#' 1 3 10
1#4#7#10
应用技巧:
复制代码代码示例:
[toy@centos5 ~]$ a=($(seq 1 3 10))
[toy@centos5 ~]$ echo ${a[1]} 4 [toy@centos5 ~]$ echo ${a[@]} 1 4 7 10
生成连续相同字符:
复制代码代码示例:
[toy@centos5 ~]$ seq -s '#' 30 | sed -e 's/[0-9]*//g'
以上例子通过加入间隔字符‘#’后,替换掉数字,生成连续相同字符’#’。 (责任编辑:IT) |