java中棧和堆的區(qū)別 數(shù)組保存在堆里還是棧里?
數(shù)組保存在堆里還是棧里?首先,單獨編寫,以便于解釋int[]a=null//聲明數(shù)組,并參考a=New int[5]//分配內(nèi)存地址。好的,數(shù)組引用,也就是a,當您聲明它時,它將在堆棧中打開一個地址空
數(shù)組保存在堆里還是棧里?
首先,單獨編寫,以便于解釋int[]a=null//聲明數(shù)組,并參考a=New int[5]//分配內(nèi)存地址。好的,數(shù)組引用,也就是a,當您聲明它時,它將在堆棧中打開一個地址空間。也就是說,第一步和第二步的功能是在堆中創(chuàng)建一個連續(xù)地址系統(tǒng)。具體需求取決于您的類型和數(shù)組的長度??傊?,數(shù)組引用存儲在堆棧中,實例在堆中打開連續(xù)空間,堆棧中的空間指向堆的第一個地址。讓我們解釋一下為什么我們通常說new不能在數(shù)組上運行??因為此時堆中沒有分配內(nèi)存地址。所以你的數(shù)據(jù)沒有地方存儲和操作。
為什么我覺得C語言中二維數(shù)組沒用,明明兩個一維數(shù)組就能解決,為什么要有二維數(shù)組存在?
從底層實現(xiàn)來看,無論是一維數(shù)組、二維數(shù)組還是多維數(shù)組,都是以一維方式排列在內(nèi)存中。用一維陣列模擬多維陣列。從這一點出發(fā),一維陣列可以解決多維陣列的問題。常用的模擬方法:
將二維數(shù)組a[M][n]表示為一維數(shù)組a[M*n
]用[y*nx]代替[y][x
]注意這里用一維數(shù)組代替二維數(shù)組
從代碼清晰易讀的角度來看,二維數(shù)組和多維數(shù)組是不同的有意義。有很多數(shù)據(jù)可以用二維數(shù)組或多維數(shù)組來表示。如果數(shù)據(jù)以適當?shù)姆绞奖硎?,算法將簡潔明了。典型?shù)據(jù)適合二維數(shù)組表示,如平面圖形、矩陣。采用二維數(shù)組,程序清晰易讀;采用一維數(shù)組,可讀性要低得多。
與匯編語言相比,C提供了一些數(shù)據(jù)抽象,如數(shù)組、結(jié)構(gòu)和聯(lián)合。事實上,沒有這些抽象,程序仍然可以被編程。但C語言的優(yōu)點是具有高度的抽象性,非常適合于系統(tǒng)級程序的開發(fā)和維護。如果您認為C語言提供的抽象級別太高,那么匯編可能更適合您的項目。如果您認為C語言提供的抽象級別太低,那么有很多選擇。從C、java到各種新語言,您可以嘗試替換它們。