关于栈内存(Stack)和堆内存(Heap)

 

堆相对进程来说是全局的,能够被所有线程访问;而栈是线程局部的,只能本线程访问。
  同样道理,由于堆是所有线程共有的,从堆里面申请内存要进行相关的加锁操作,因此申请堆内存的复杂度和时间开销比栈要大很多;从栈里面申请内存,虽然又简单又快,但是栈的大小有限,分配不了太多内存。

 

JVM的内存
  在Java虚拟机规范中,
提及了如下几种类型的内存空间:
  ◇栈内存(Stack):每个线程私有的。
  ◇堆内存(Heap):所有线程公用的。
  ◇方法区(Method Area):有点像以前常说的“进程代码段”,这里面存放了每个加载类的反射信息、类函数的代码、编译时常量等信息。
  ◇原生方法栈(Native Method Stack):主要用于JNI中的原生代码,平时很少涉及。
 

 

你可能感兴趣的:(jvm,虚拟机,jni)