Ⅰ 在linux中我使用gcc進行編譯,定義數組時,如下所示 int a[5] = {10, a[9] =5};
初始化按照初始化表中的值的順序依次給數組每個元素賦值。因此,a0賦值為10,a[1]賦值為表達式(a[9]=5)的結果。賦值號的返回值為左值的引用,因此先將a[9]賦值為5,然後返回a[9]的引用對a[1]賦值,因此a[1]=a[9]=5。a[2]~a[8]處於未賦值狀態。
Ⅱ linux腳本,在一個循環中賦值一個數組
數組的賦值操作有問題,改成下面這樣:
for ubootfile in $uboot_list
do
FILE=`find . -name $ubootfile -print -quit`
if [ -n "$FILE" ]; then
a=(${a[@]} $FILE)
else
b=(${b[@]} $FILE)
fi
done
echo "found files:"
echo ${a[@]}
echo "missing files:"
echo ${b[@]}
下面是數組操作的講解,請參考:
數組作為一種特殊的數據結構在任何一種編程語言中都有它的一席之地,當然bashshell也不例外。本文就shell數組來做一個小的總結。
在這里只討論一維數組的情況,關於多維數組(事實上,你得用一維數組的方法來模擬),不涉及。這里包括數組的復制,計算,刪除,替換。
數組的聲明:
1)array[key]=value # array[0]=one,array[1]=two
2)declare -a array # array被當作數組名
3)array=(value1 value2 value3 ... )
4)array=([1]=one [2]=two [3]=three ... )
5)array="one two three" # echo ${array[0|@|*]},把array變數當作數組來處理,但數組元素只有字元串本身
數組的訪問:
1)${array[key]} # ${array[1]}
數組的刪除
1)unsetarray[1] # 刪除數組中第一個元素
2)unset array # 刪除整個數組
計算數組的長度:
1)${#array}
2)${#array[0]}#同上。 ${#array[*]} 、${#array[@]}。注意同#{array:0}的區別
數組的提取
從尾部開始提取:
array=( [0]=one [1]=two [2]=three [3]=four )
${array[@]:1} # two three four,除掉第一個元素後所有元素,那麼${array[@]:0}表示所有元素
${array[@]:0:2} # one two
${array[@]:1:2} # two three
子串刪除
[root@localhostdev]# echo ${array[@]:0}
one two three four
[root@localhostdev]# echo ${array[@]#t*e} # 左邊開始最短的匹配:"t*e",這將匹配到"thre"
one two e four
[root@localhostdev]# echo ${array[@]##t*e} # 左邊開始最長的匹配,這將匹配到"three"
[root@localhostdev]# array=( [0]=one [1]=two [2]=three [3]=four )
[root@localhostdev]# echo ${array[@] %o} # 從字元串的結尾開始最短的匹配
one tw three four
[root@localhostdev]# echo ${array[@] %%o} # 從字元串的結尾開始最長的匹配
one tw three four
子串替換
[root@localhostdev]# array=( [0]=one [1]=two [2]=three [3]=four )
第一個匹配到的,會被刪除
[root@localhostdev]# echo ${array[@] /o/m}
mne twm three fmur
所有匹配到的,都會被刪除
[root@localhostdev]# echo ${array[@] //o/m}
mne twm three fmur
沒有指定替換子串,則刪除匹配到的子符
[root@localhostdev]# echo ${array[@] //o/}
ne tw three fur
替換字元串前端子串
[root@localhostdev]# echo ${array[@] /#o/k}
kne two three four
替換字元串後端子串
[root@localhostdev]# echo ${array[@] /%o/k}
one twk three four
Ⅲ linux shell編程中怎樣編歷數組
上網路上面搜啊
Ⅳ linux shell 建立一個整形數組
看了樓主的問題才知道原來bash還可以用數組。於是谷歌了下,發現這篇文章,http://www.centoscn.com/shell/2013/0331/196.html樓主可以參考一下。使用起來跟C裡面差不多 譬如 static int a[]={1,2,3,4,5}。
Ⅳ 關於Linux數組的使用
192.168.1.1 是字元串,不是數字, 不能++. 當shell看到第一個"."時出錯.
你想做什麼?
Ⅵ linux C下,怎麼定義一個byte數組
windows系統 在windows.h中已經定義,包含(#include "windows.h")就可以了。 linux系統下自已定義: #define BYTE unsigned char
Ⅶ 如何在嵌入式linux系統下用c語言申請一個大於640k的數組
……
對這沒研究,不過我記得,數組的處理方式是最緩慢而且最不利系統運行的數據處理方法。超大的數組會導致程序可能存在下標處理溢出或者別的什麼問題。
超大數據應該用緩沖吧?自己處理緩沖數據。我想 Linux 下面應該有好用的超大數據存儲處理的函數庫。
你為啥還要死磕數組呢……計算機編程有一個很重要的課程就是數據演算法,就是為了解決這個問題而開設的……
Ⅷ linux,shell如何把字元串變成數組
echo $url | cut -d , -f 1
cut是切割命令,-d表示分隔符,這里是逗號,-f表示取第幾個,這里是第一個
注意和數組不一樣,數組是取第0個。
Ⅸ 怎樣將linux中一系列文件的地址放入數組中
cp text mulu1 mulu2 mulu3 會被 cp 認為是把 text mulu1 mulu2 這三個東西復制到 mulu3 里 用 for 語句: for d in mulu1 mulu2 mulu3 ; do cp -v text $d; done
Ⅹ Linux Shell awk中怎麼調用數組和for循環
echo|awk'
{
array[1]=1
array[2]=2
array[3]=3
array[4]=4
array[5]=5
for(i=1;i<=5;++i){
printarray[i]
}
}'