java 的“mwq”_java的对象模型 - osc_mwqvsfzo的个人空间 - OSCHINA - 中文开源技术交流社区...
java中的對象在內(nèi)存中,究竟是怎樣一種存在?
這篇隨筆,我們就來一探究竟??赡懿粔蛏钊?#xff0c;但是我們把理解到位,深入到我們需要的程度這樣即可。
先來看下jvm的內(nèi)存模型:
程序計數(shù)器
虛擬機棧和本地方法棧
堆
方法區(qū)(運行時常量池)
這就是整個的jvm的內(nèi)存模型的組成部分,那么對象是存儲在Heap Area中的,也就是堆空間。
知道了存儲的地方,那具體究竟是怎么存儲的呢?我們繼續(xù)。
注:全篇所說的jvm都是特指HotSpot JVM。
(剛在看OOP_CLASS)的過程中,詳細(xì)看了一篇博客寫的很清晰,把相關(guān)的內(nèi)容寫的很清晰??戳讼陆榻B是個15年畢業(yè)的兄弟,現(xiàn)在已經(jīng)是阿里的技術(shù)專家了,再次印證的那個道理,人必須有個勤字,一勤天下無難事,還有就是恒字,反省我自己的技術(shù)生涯,如果能做到這兩個字也早起來了。痛定思痛繼續(xù)努力。
之前其實翻過HotSpot的Klass部分的源碼,但當(dāng)時并沒有深刻的理解,今天再來引用一下。
先看整個的結(jié)構(gòu):
Java對象分為兩個部分在jvm中,一個是對象本身,一個是對象對應(yīng)的類,在jvm的代碼oopsHierarchy.hpp中可以看到,代表對象的是下邊這些:
#ifndef CHECK_UNHANDLED_OOPS
typedefclass oopDesc*oop;
typedefclass instanceOopDesc*instanceOop;
typedefclass methodOopDesc*methodOop;
typedefclass constMethodOopDesc*constMethodOop;
typedefclass methodDataOopDesc*methodDataOop;
typedefclass arrayOopDesc*arrayOop;
typedefclass objArrayOopDesc*objArrayOop;
typedefclass typeArrayOopDesc*typeArrayOop;
typedefclass constantPoolOopDesc*constantPoolOop;
typedefclass constantPoolCacheOopDesc*constantPoolCacheOop;
typedefclass klassOopDesc*klassOop;
typedefclass markOopDesc*markOop;
typedefclass compiledICHolderOopDesc*compiledICHolderOop;#else
代表類的是下邊這些:注釋上也寫了,klass的結(jié)構(gòu)和oop的結(jié)構(gòu)是分開的
//The klass hierarchy is separate from the oop hierarchy.
classKlass;classinstanceKlass;classinstanceMirrorKlass;classinstanceRefKlass;classmethodKlass;classconstMethodKlass;classmethodDataKlass;classklassKlass;classinstanceKlassKlass;classarrayKlassKlass;classobjArrayKlassKlass;classtypeArrayKlassKlass;classarrayKlass;classobjArrayKlass;classtypeArrayKlass;classconstantPoolKlass;classconstantPoolCacheKlass;classcompiledICHolderKlass;#endif //SHARE_VM_OOPS_OOPSHIERARCHY_HPP
為什么要分開,據(jù)說是為了避免像c++那樣實現(xiàn)多態(tài)的時候需要每個對象維護一個虛方法表,而分開的。這樣oopDesc里我們可以看到,對象的定義里,對象頭除了MarkWord之外,就是類型指針,而類型指針其實就是方法區(qū)的instanceKlass。表示的就是類在jvm里的實例信息。
classoopDesc {
friendclassVMStructs;private:volatilemarkOop _mark; // 1 MarkWord
union _metadata { // 2 類型指針
wideKlassOop _klass;
narrowOop _compressed_klass;
} _metadata;// ...省略private://field addresses in oop
void* field_base(int offset) const;
jbyte* byte_field_addr(int offset) const;
jchar* char_field_addr(int offset) const;
jboolean* bool_field_addr(int offset) const;
jint* int_field_addr(int offset) const;
jshort* short_field_addr(int offset) const;
jlong* long_field_addr(int offset) const;
jfloat* float_field_addr(int offset) const;
jdouble* double_field_addr(int offset) const;
address* address_field_addr(int offset) const;
這個就是OopDesc.hpp的代碼,而我們要的InstanceOop是這樣的
#include "oops/oop.hpp"
//An instanceOop is an instance of a Java Class//Evaluating "new HashTable()" will create an instanceOop.
class instanceOopDesc : publicoopDesc {// 省略};#endif //SHARE_VM_OOPS_INSTANCEOOP_HPP
明顯看到instanceOopDesc就是繼承自oopDesc的。所以我們來分析下oopDesc的結(jié)構(gòu)。
我們知道Java對象的組成部分是:對象頭(Header)/ 實例數(shù)據(jù)(Instance Data)/ 對齊填充(Padding) 三個部分。而對象頭又包括兩部分:MarkWord 和 類型指針。
代碼中明顯可以看到對象頭的部分,我們已經(jīng)標(biāo)注出來,而實例數(shù)據(jù)就在下邊的各種field里。
看到了OopDesc表示的對象,我們再來看下Klass表示的類吧。
總結(jié)
以上是生活随笔為你收集整理的java 的“mwq”_java的对象模型 - osc_mwqvsfzo的个人空间 - OSCHINA - 中文开源技术交流社区...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: <audio>标签HTML5
- 下一篇: java web服务 分层,java w