關於linux陣列定義,以及生成方法,請看:linux shell 動態生成 陣列系列 seq使用技巧 。這裡我主要說的是高效生成list 字串,還有陣列方法。
一、seq方法生成:
1 2 3 |
[chengmo@centos5 shell]$ aNumList=$(seq 100); [chengmo@centos5 shell]$ echo $aNumList 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 |
aNumList得到是字串,不同之處以:空格分隔開。在linux裡面,可以把它看作是list. 可以通過for…in 迴圈讀取。
1 2 3 4 5 |
[chengmo@centos5 shell]$ for i in $aNumList;do echo $i;done; 1 2 3 4…… |
如果需要生成array只需要將$(seq 100) 再加個”()”即可。
1 2 3 4 5 |
[chengmo@centos5 ~]$ aNumList=($(seq 100)); [chengmo@centos5 ~]$ echo $aNumList 1 [chengmo@centos5 ~]$ echo ${#aNumList[@]} 100 |
長度是100的陣列。
二、通過內部{begin..end}生成
這種方法生成seq非常方便。通過內部運算子完成。
1 2 3 4 5 6 7 8 9 10 11 12 13 |
[chengmo@centos5 ~]$ echo {1..10} 1 2 3 4 5 6 7 8 9 10 [chengmo@centos5 ~]$ for a in {1..10};do echo $a;done; 1 2 3 4 5 6 7 8 9 10 |
三、效能比較
1 2 |
[chengmo@centos5 ~]$ time echo {1..100} 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 |
real 0m0.000s
user 0m0.001s
sys 0m0.000s
1 2 |
[chengmo@centos5 ~]$ time echo $(seq 100) 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 |
real 0m0.003s
user 0m0.002s
sys 0m0.001s
從上面可以看到,{begin..end}速度比seq呼叫快了不少了。 以後呼叫時候可以考慮通過內部操作符完成。