java 栈 大小_java – JVM堆栈大小规范
Question, what does 1 MB stack size states in JVM as I have no idea what size a stack frame of?
1 MB默認(rèn)線程堆棧大小意味著每個線程默認(rèn)具有1MB(1048576字節(jié))的堆棧空間.例外情況是,如果您的代碼使用其中一個Thread構(gòu)造函數(shù)創(chuàng)建一個線程,您可以在其中提供堆棧大小參數(shù).
堆棧幀的大小取決于被調(diào)用的方法.它需要保存方法的參數(shù)和局部變量,因此幀大小取決于它們的大小.每個幀還需要(我認(rèn)為)兩個額外的單詞來保存已保存的幀指針和保存的返回地址.
請注意,在遞歸算法中,您可以為一個“遞歸級別”擁有多個堆棧幀.對于writeObject(在Java 8中),使用的算法是遞歸的,并且每個級別的數(shù)據(jù)結(jié)構(gòu)通常有4個幀被序列化:
writeObject0
writeOrdinaryObject
writeSerialData
defaultWriteFields
writeObject0
etcetera
由于編譯器的差異以及ObjectInputStream / ObjectOutputStream的實現(xiàn)的變化,實際的幀大小將取決于平臺.您最好嘗試(粗略地)測量所需的堆棧空間,而不是嘗試從第一原則預(yù)測幀大小.
One more question, does every thread has 3000k stack size if I put a JVM option of -Xss3000k ?
是的……除了我上面描述的例外.
解決您的困境的一個可能的解決方案是創(chuàng)建一個特殊的線程,其中包含一個用于序列化的巨大堆棧.反序列化將需要具有大堆棧的類似線程.對于其余的線程,默認(rèn)的堆棧大小應(yīng)該沒問題.
其他可能的方案:
>實現(xiàn)writeReplace和readResolve方法,將epc對象的父結(jié)構(gòu)展平為一個數(shù)組,這樣就不會得到深度遞歸. (顯然,需要非遞歸地完成展平/不展平.)
>在調(diào)用writeObject等之前,請執(zhí)行相同的展平操作.
>使用不同的序列化機制,或者可能是自定義機制.
總結(jié)
以上是生活随笔為你收集整理的java 栈 大小_java – JVM堆栈大小规范的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python重写和装饰器_python装
- 下一篇: 图像太宽无法输出请裁剪图像或降低分辨率然