淺議C語言中數(shù)組和指針的互操作

字號:

曾聽好多朋友說,C是一種懷舊的語言,因為它的歷史很久遠(yuǎn),然而自從各種面向?qū)ο蟮木幊陶Z言的相續(xù)出現(xiàn)讓它的影響力日減。當(dāng)然了,這是無可非議的,但是C的高效性是其他語言無妨比擬的,所以我們有必要把握其中的精華與奧妙,也就有必要知道其中的基本的數(shù)據(jù)結(jié)構(gòu)的比如數(shù)組,稍微有點深度的堆棧、列表、結(jié)構(gòu)體等的操作和實現(xiàn)。指針也是C語言中的一個很優(yōu)秀靈活的結(jié)構(gòu),對它的了解也是必不可少的。
    我們一般都認(rèn)為數(shù)組是一維的數(shù)據(jù)存儲結(jié)構(gòu),因為二位數(shù)組或者說矩陣都可以看作是多個一維數(shù)組的組合結(jié)構(gòu),定義在其上的數(shù)據(jù)存儲訪問方式是一樣的。所以一維數(shù)組是其中最基礎(chǔ)的最重要的部分,只有理解了此類數(shù)據(jù)結(jié)構(gòu)的本質(zhì)才能觸類旁通了。
    數(shù)組(array)是若干同類變量的聚合,允許通過統(tǒng)一的名字飲用其中的變量。所以數(shù)組也就是一個同一類型的數(shù)據(jù)的有限集合??梢酝ㄟ^下表來訪問數(shù)組中的某一/些數(shù)組元素。在C語言中數(shù)組都由連續(xù)的內(nèi)存區(qū)域構(gòu)成(有時候,不一定是這樣),最低地址對應(yīng)首元素,數(shù)組的下標(biāo)是從0開始的,所以首元素也就是數(shù)組下標(biāo)為0的元素,的地址對應(yīng)最末的元素,即第N-1個元素(如果我們定義的數(shù)組為N元)。
    數(shù)組的定義方式:
    在C語言中允許在聲明數(shù)組的時候同時對其進(jìn)行初始化,也可以把聲明和定義放在不同的位置,初始化的一般的類似于如下的表達(dá)式:
    type_specifier array_name[size1]...[sizeN] = {value_list};
    其中vlaue_list是由逗號(,)分隔的常量表,常量表必須和type_specifier兼容。最后由分號與下一個語句分隔。由此可見一維數(shù)組的定義方式為:
    type_specifier array_name[size] = {value_list};
    如下:char hello[12] = {’H’,’e’,’l’,’l’,’o’,’,’,’ ’,’w’,’o’,’r’,’l’,’d’,’\0’};