jvm

jvm: java Virtual Machine(Java虚拟机),class文件执行载体;
jmm: (Java Memory Model) java内存模型.描述线程本地内存和主内存之间的抽象关系。线程A和线程B之间通讯,需要通过主内存。

  • 1 jvm内存
    多数 JVM 将内存区域划分为 Method Area(Non-Heap)(方法区),Heap(堆),Program Counter Register(程序计数器), VM Stack(虚拟机栈,也有翻译成JAVA 方法栈的),Native Method Stack (本地方法栈),其中Method Area和Heap是线程共享的,VMStack,Native Method Stack 和Program Counter Register是非线程共享的。
    jvm/jmm总结
  • 2 jmm内存模型
    JMM规定了所有的变量都存储在主内存(Main Memory)中。每个线程还有自己的工作内存(Working Memory),线程的工作内存中保存了该线程使用到的变量的主内存的副本拷贝,线程对变量的所有操作(读取、赋值等)都必须在工作内存中进行,而不能直接读写主内存中的变量(volatile变量仍然有工作内存的拷贝,但是由于它特殊的操作顺序性规定,所以看起来如同直接在主内存中读写访问一般)。不同的线程之间也无法直接访问对方工作内存中的变量,线程之间值的传递都需要通过主内存来完成。
    jvm/jmm总结
    线程1和线程2要想进行数据的交换一般要经历下面的步骤:
      1.线程1把工作内存1中的更新过的共享变量刷新到主内存中去。
      2.线程2到主内存中去读取线程1刷新过的共享变量,然后copy一份到工作内存2中去。

相关文章:

  • 2021-12-12
  • 2021-09-20
  • 2021-07-08
  • 2021-09-09
  • 2021-09-11
  • 2021-11-30
  • 2021-04-10
猜你喜欢
  • 2022-12-23
  • 2021-08-12
  • 2021-08-27
  • 2021-08-31
  • 2021-04-14
  • 2021-05-27
  • 2021-12-11
相关资源
相似解决方案