Java中數組在內存中的存放原理?


版權聲明:本文為博主原創文章,未經博主允許不得轉載。 https://blog.csdn.net/yangyong0717/article/details/79165685
Java中數組被實現為對象,它們一般都會因為記錄長度而需要額外的內存。對於一個原始數據類型的數組,一般需要24字節的頭信息再加上保存值所需的內存,其中24字節的頭信息分別包含以下幾個部分。

 

下面分別分析一維、二維、三維的數組存儲情況。

下面首先對一維數組進行分析,以int[]型數組為例,假設數組長度為N,那么需要的內存占用(24+4N)個字節,原因分析比較簡單,圖解示例如下:即占用內存總量=頭信息內存+數組N個int值占用內存。

 

 

對於二維數組進行分析,首先對於多維數組的概念,大家可以參考這篇博客:https://www.cnblogs.com/chenyangyao/p/5222696.html

多維數組實際存儲的時候就是一維數組,高維數組不斷的降維轉化為低維數組,例如二維數組就是一個數組的數組,即每一個一維數組里面包含一個另外一個一維數組的引用。以一個MxN的double類型的二維數組為例,其實際占用內存總量為:(8MN+32M+24) 約等於8MN。這里仍然以圖示進行講解:(這里以64位架構的計算機為例,每個對象引用地址為8位)

 

對於三維數組的分析,仍然以M x N x Q的double數組為例,與上面的分析過程類似,可以將三維數組轉化成一個一維數組,該一維數組保存指向二維數組的引用。對於二維數組的分析過程則和上面的過程一樣。

則占用的內存總共為:24 + 8M + M*(24 + 8N) + M*N(24 + 8Q)字節。

對於更高維的數據存儲容量,可以按照相似的方法進行分析即可。
---------------------
作者:yangyongUestc
來源:CSDN
原文:https://blog.csdn.net/yangyong0717/article/details/79165685
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM