ARM匯編中標(biāo)號的引用在匯編和C語言中區(qū)別
1018: a1700048 0 NOTYPE GLOBAL DEFAULT 1 _bss_start
1083: a1700044 0 NOTYPE GLOBAL DEFAULT 1 _armboot_start
1142: a1700000 0 NOTYPE GLOBAL DEFAULT 1 _start
1197: a171b070 0 NOTYPE GLOBAL DEFAULT ABS __bss_start
在匯編中,標(biāo)號==地址,對標(biāo)號的引用就是對標(biāo)號對應(yīng)的地址操作,如_armboot_start,其值就是a1700044,如果想取得其對應(yīng)內(nèi)存地址中的數(shù)據(jù),就需要ldr等指令。舉個不恰當(dāng)?shù)睦?,如果在匯編語言中也可以有類似x-y的操作的話
monitor_flash_len=_bss_start - _armboot_start=0xa1700048 - 0xa1700044 = 4
這是完全正確的。
然而,在C語言中,其結(jié)果卻不是這樣的。在C中,對匯編中的全局標(biāo)號的引用,其值不再是地址,而是地址對應(yīng)內(nèi)存單元中的數(shù)據(jù),所以對于C語言
monitor_flash_len = _bss_start - _armboot_start = a171b070 - a1700000 = 1b070
在C語言中,對基本數(shù)據(jù)類型變量的引用,其值就是對應(yīng)內(nèi)存中的數(shù)據(jù),而對于復(fù)雜數(shù)據(jù)類型及函數(shù),其標(biāo)識符名是指向首地址的指針,其值是它們的首地址。
或許可以這樣理解,由于對于基本數(shù)據(jù)類型來說,其地址和對應(yīng)內(nèi)存單元中的數(shù)據(jù)剛好是一一對應(yīng)的,對變量的引用目的也是希望對內(nèi)存中的數(shù)據(jù)進(jìn)行操作,所以默認(rèn)是取得變量對應(yīng)內(nèi)存單元中的數(shù)據(jù);而對于復(fù)雜數(shù)據(jù)類型及函數(shù)來說,利用一個地址取得全部數(shù)據(jù)是不可能的,所以就用標(biāo)明首地址的方式,加上地址的線性連續(xù),便可以通過首地址取得全部數(shù)據(jù),這是通過對指針(地址)的操作來實現(xiàn)的。
評論