JAVA并发编程之Thread StackSize(四)

一、Thread StackSize

虚拟机栈是线程私有,JAVA中每个线程都有一个栈空间,stackSize就是用来设置该空间的大小。

1、Thread 构造函数默认0

JAVA并发编程之Thread StackSize(四)

2、Thread 可以设置线程栈大小的构造函数

JAVA并发编程之Thread StackSize(四)

与JVM 设置 -Xss的区别 

  1.   Thread 是针对指定的线程
  2.  -Xss是全局性控制每个线程的栈大小

stackSize与栈深度(stack height,就是递归的层数):在HostSpotVM中,stackSize值较大时会加大线程栈的深度;值较小时同时存在的线程数较多,以避免创建过多线程出现OutOfMemoryError(或者其他Error)

二、Thread stackSize 与-Xss的关系

  • 当设置stackSize属于<=0 时,以-Xss为准
  • 当设置stackSize属于(0, 4k]区间时,设置的-Xss会失效,栈空间取默认值1M
  • 当设置stackSize属于(4k, 64k]区间时,设置的-Xss会失效,栈空间取4k。
  • 当设置stackSize属于(64k, 128k]区间时,设置的-Xss会失效,栈空间取64k。
  • 当设置stackSize属于 >128k 时,设置的-Xss会失效,栈空间取stackSize本身

JAVA并发编程之Thread StackSize(四)

JVM配置:-Xmx256m -Xms256m -Xss256k  

  1. SatckSize等于默认值0:height=3696 
  2. SatckSize等于1024*1024(1m):height=24818
  3. SatckSize等于1024*3(3k):height=23198
  4. SatckSize等于1024*5(5k):height=266  
  5. SatckSize等于1024*65(65k):height=1071
  6. SatckSize等于1024*129(129k):height=2128

stackSize没有特殊的需求不需要修改,让他与平台一致就好,因为它本身的作用和范围取决于平台,在跨平台迁移时,需要检查是否需要修改这个参数;stackSize 用于精细地控制线程数和栈深度的关系,如果有些算法用递归实现,栈深度较大,可以针对性的修改。