標題:
c語言中數(shù)組訪問和指針訪問的區(qū)別
[打印本頁]
作者:
51黑黑黑
時間:
2016-2-21 15:37
標題:
c語言中數(shù)組訪問和指針訪問的區(qū)別
在實際應(yīng)用中,我們往往這樣使用指針和數(shù)組,例如:
unsigned char *a="abcdefg";
unsigned char val = a[5];
或者
unsigned char a[10]="abcdefg";
unsigned char val = a[5];
并且我們發(fā)現(xiàn)兩種情況下我們都能得到正確的值val='f';
s所以許多人都認為數(shù)組名訪問和指針訪問是一樣的,事實上不然,以rmdk為例:
我們先看看第一種情況:
編寫如下代碼:
unsigned int addr;
char val;
char *a="abcdefgh";
int main(void )
{
val = a[5];
while(1)
{
}
}
反匯編如下:
而a的地址如下:
我們通過單步運行發(fā)現(xiàn),程序總是分三步獲取正確的值:
1、先獲取a的地址20000000
2、然后取20000000地址所指向的值08000296,
3、取08000296+5地址里的值‘f’
下面,我們看看第二種情況下,系統(tǒng)是如何取到正確的值的:
編寫如下程序。
char val;
char a[10]="abcdefgh";
int main(void )
{
val = a[5];
while(1)
{
}
}
反匯編如下:
a的存儲地址如下:
通過對比我們發(fā)現(xiàn),將a定義為數(shù)組時系統(tǒng)通過如下不步驟取得正確的值:
1、取a的地址
2、取a+5地址的值
所以,雖然取得了相同的結(jié)果,但是實現(xiàn)的方式卻是不同的。
同時也證明了聲明數(shù)組變量時,使用extern unsigned char a[] 與extern unsigned chara[100]是等價的,因為他都告訴編譯器這是一個數(shù)組,一個內(nèi)存地址,數(shù)組內(nèi)的內(nèi)容可以通過訪問這個地址獲取。
那么,把數(shù)組作為函數(shù)參數(shù)時是怎么樣的呢?
例如定義一個函數(shù)
unsigned int fun(unsigned char a[],unsigned int * len)
{
...............
}
大家都知道,函數(shù)參數(shù)的傳遞其實是一種值傳遞的方式,在rmdk編譯器中,當參數(shù)不超過四個時,總是使用R0---R3來傳遞參數(shù),而返回參數(shù)則使用R0來傳遞。其余的參數(shù)則是使用堆棧傳遞,傳遞參數(shù)前將這些參數(shù)入棧,在函數(shù)內(nèi)部將這些參數(shù)出戰(zhàn)。假設(shè)傳遞了一個數(shù)組,不可能將所有的參數(shù)全部壓棧,效率太低,所以編譯器在處理
這種情況時,只是將傳遞的指針所指向的地址壓棧。換句話說,這里的a其實被解釋為指針了,它等價于unsigned char *a,這是唯一的數(shù)組和指針等價的地方。
歡迎光臨 (http://www.torrancerestoration.com/bbs/)
Powered by Discuz! X3.1