国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

如何得到一個對象真實的內(nèi)存大小

blankyao / 2667人閱讀

摘要:如何得到一個對象真實的內(nèi)存大小介紹一款工具可方便的測量一個對象真實占用內(nèi)存大小如有這么一個對象先看一個空對象的內(nèi)存占用量可知一個對象三個引用共占了字節(jié)逐個賦值后占用內(nèi)存是多少呢給賦值一個對象占用字節(jié)于是給賦值后對象變成了字節(jié)了。

如何得到一個對象真實的內(nèi)存大小

介紹一款工具(memory-measurer)可方便的測量一個對象真實占用內(nèi)存大小 如有這么一個User對象

</>復(fù)制代碼

  1. public class User {
  2. private Integer id;
  3. private String mobile;
  4. private Date createTime;
  5. }

先看一個空User對象的內(nèi)存占用量

</>復(fù)制代碼

  1. User u = new User();
  2. System.out.println(MemoryMeasurer.measureBytes(u)); //24
  3. System.out.println(ObjectGraphMeasurer.measure(u)); //Footprint{Objects=1, References=3, Primitives=[]}

可知一個對象 三個引用 共占了24字節(jié)

逐個賦值后占用內(nèi)存是多少呢?

</>復(fù)制代碼

  1. // 給id賦值
  2. Integer id = new Integer(1);
  3. System.out.println(MemoryMeasurer.measureBytes(id)); // 16
  4. u.setId(id);
  5. System.out.println(MemoryMeasurer.measureBytes(u)); // 40
  6. System.out.println(ObjectGraphMeasurer.measure(u)); //Footprint{Objects=2, References=3, Primitives=[int]}

一個Integer對象占用16字節(jié) 于是給id賦值后 user對象變成了24+16=40字節(jié)了。

</>復(fù)制代碼

  1. // 給mobile賦值
  2. String mobile = "13600000001";
  3. System.out.println(MemoryMeasurer.measureBytes(mobile)); // 64
  4. u.setMobile(mobile);
  5. System.out.println(MemoryMeasurer.measureBytes(u)); // 104
  6. System.out.println(ObjectGraphMeasurer.measure(u)); //Footprint{Objects=4, References=4, Primitives=[int x 2, char x 11]}

一個11位長的mobile字符串對象占用了64字節(jié),于是user對象變成了40+64=104字節(jié)

</>復(fù)制代碼

  1. // 給createTime賦值
  2. Date createTime = new Date();
  3. System.out.println(MemoryMeasurer.measureBytes(createTime)); // 24字節(jié)
  4. u.setCreateTime(createTime);
  5. System.out.println(MemoryMeasurer.measureBytes(u)); // 128
  6. System.out.println(ObjectGraphMeasurer.measure(u)); //Footprint{Objects=5, References=5, Primitives=[int x 2, long, char x 11]}

可知一個Date對象占用了24字節(jié), 于是全部屬性不為空的一個User對象占用內(nèi)存為128字節(jié)。

另外還可以通過另外一個工具--JOL (Java Object Layout)--可知更詳細(xì)的Footprint信息

通過上面的工具我們只是知道一個空User對象占用了24字節(jié)以及簡單的

</>復(fù)制代碼

  1. Footprint{Objects=1, References=3, Primitives=[]}

通過此工具可知這24個字節(jié)是怎么分配的了

</>復(fù)制代碼

  1. System.out.println(ClassLayout.parseClass(User.class).toPrintable());
  2. memorymeasurer.User object internals:
  3. OFFSET SIZE TYPE DESCRIPTION VALUE
  4. 0 12 (object header) N/A
  5. 12 4 Integer User.id N/A
  6. 16 4 String User.mobile N/A
  7. 20 4 Date User.createTime N/A
  8. Instance size: 24 bytes
  9. Space losses: 0 bytes internal + 0 bytes external = 0 bytes total

上面我們知道一個Integer對象占用了16字節(jié) 看這16個字節(jié)是怎么分配的

</>復(fù)制代碼

  1. System.out.println(ClassLayout.parseClass(Integer.class).toPrintable());
  2. java.lang.Integer object internals:
  3. OFFSET SIZE TYPE DESCRIPTION VALUE
  4. 0 12 (object header) N/A
  5. 12 4 int Integer.value N/A
  6. Instance size: 16 bytes
  7. Space losses: 0 bytes internal + 0 bytes external = 0 bytes total

上面我們知道一個11位長的String對象占用了64字節(jié) 看其是怎么分配的

</>復(fù)制代碼

  1. System.out.println(ClassLayout.parseClass(String.class).toPrintable());
  2. java.lang.String object internals:
  3. OFFSET SIZE TYPE DESCRIPTION VALUE
  4. 0 12 (object header) N/A
  5. 12 4 char[] String.value N/A
  6. 16 4 int String.hash N/A
  7. 20 4 (loss due to the next object alignment)
  8. Instance size: 24 bytes
  9. Space losses: 0 bytes internal + 4 bytes external = 4 bytes total

即一個空String對象占用了24字節(jié)

</>復(fù)制代碼

  1. System.out.println(ClassLayout.parseClass(char[].class).toPrintable());
  2. [C object internals:
  3. OFFSET SIZE TYPE DESCRIPTION VALUE
  4. 0 16 (object header) N/A
  5. 16 0 char [C. N/A
  6. Instance size: 16 bytes
  7. Space losses: 0 bytes internal + 0 bytes external = 0 bytes total

一個長度為0的char數(shù)組占了16字節(jié) 于是11位長的char數(shù)組占用字節(jié)為: 16+2*11=38 因為需要按8字節(jié)對齊 于是還得加上2字節(jié)的填充符 于是變成了40字節(jié)。 所以一個11位長的字符串的占用字節(jié)為24+40=64

補充 memory-measurer如何使用

</>復(fù)制代碼

  1. git clone https://github.com/msteindorfer/memory-measurer
  2. cd memory-measurer
  3. mvn clean install

pom文件中添加依賴

</>復(fù)制代碼

  1. com.github.msteindorfer
  2. memory-measurer
  3. 0.1.0-SNAPSHOT

運行時時顯式添加vm參數(shù) 如

</>復(fù)制代碼

  1. -javaagent:/Users/zhugw/workspace/memory-measurer/target/memory-measurer-0.1.0-SNAPSHOT.jar
jol使用說明

只需添加依賴

</>復(fù)制代碼

  1. org.openjdk.jol
  2. jol-core
  3. 0.9
相關(guān)參考文檔

https://github.com/msteindorf...
http://openjdk.java.net/proje...
http://blog.omalley.id.au/201...

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/65175.html

相關(guān)文章

  • [譯]GC專家系列5-Java應(yīng)用性能優(yōu)化原則

    摘要:在本文中我將會介紹應(yīng)用性能優(yōu)化的一般原則。性能優(yōu)化的流程圖摘取自和合著的性能,描述了應(yīng)用性能優(yōu)化的處理流程。例如,對每臺服務(wù)器,你面臨著為單個分配堆內(nèi)存和運行個并為每個分配堆內(nèi)存的選擇。不過位能使用堆內(nèi)存最大理論值只有。 原文鏈接:http://www.cubrid.org/blog/dev-platform/the-principles-of-java-application-per...

    lufficc 評論0 收藏0
  • 圖片加載框架之UIL

    摘要:加載并顯示圖片或加載并執(zhí)行回調(diào)接口。加載圖片主要分為三類接口表示異步加載并顯示圖片到對應(yīng)的上。以上三類接口最終都會調(diào)用到這個函數(shù)進行圖片加載。不允許訪問網(wǎng)絡(luò)的圖片下載器。創(chuàng)建圖片下載器,返回一個。 1. 功能介紹 1.1 Android Universal Image Loader Android Universal Image Loader 是一個強大的、可高度定制的圖片緩存,本文簡...

    lentrue 評論0 收藏0
  • [譯]GC專家系列3-GC調(diào)優(yōu)

    摘要:原文鏈接本篇是專家系列的第三篇。但是,請記住調(diào)優(yōu)是不得已時的選擇。縮短耗時的單次執(zhí)行與相比,耗時有較明顯的增加。創(chuàng)建文件過程中,進程會中斷,因此不要在正常運行時系統(tǒng)上做此操作。因此校驗結(jié)果并根據(jù)具體的服務(wù)需要,決定是否要進行調(diào)優(yōu)。 原文鏈接:http://www.cubrid.org/blog/dev-platform/how-to-tune-java-garbage-collecti...

    leap_frog 評論0 收藏0
  • 深度解析Tengine調(diào)試與資源監(jiān)控方法論

    摘要:是由淘寶網(wǎng)發(fā)起的服務(wù)器項目。回源監(jiān)控是內(nèi)容分發(fā)網(wǎng)絡(luò)的簡稱,其分發(fā)的內(nèi)容來自用戶源站,負(fù)責(zé)回源的模塊是最重要組成部分之一,使跨越單機的限制,完成網(wǎng)絡(luò)數(shù)據(jù)的接收處理和轉(zhuǎn)發(fā)。這部分主要介紹的一些調(diào)試技巧和回源資源監(jiān)控的內(nèi)容,以及相應(yīng)的實例分享。 摘要: Tengine是由淘寶網(wǎng)發(fā)起的Web服務(wù)器項目。它在Nginx的基礎(chǔ)上,針對大訪問量網(wǎng)站的需求,提供更強大的流量負(fù)載均衡能力、全站HTTPS...

    everfight 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<