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