Java数组的内存分配
-
Java内存分为几个部分,分别是堆、栈、方法区、本地方法区、PC寄存器等。
- 堆(Heap):堆是Java中用于存储对象的和数组的内存区域,所有通过new操作符创建的对象都会在堆上分配内存。堆是一个动态分配的内存区域,大小可以根据程序需要自动调整。
- 栈(Stack):每个线程都会有一个自己的栈,用于存储方法调用和局部变量。当一个方法被调用时,一个新的栈帧会被创建并压入栈中,当方法返回时,栈帧被弹出。
- 方法区(Method Area):方法区是用于存储Java类信息、常量、静态变量、即时编译器编译后的代码等信息的内存区域。方法区与堆一样,是各个线程共享的内存区域。
- 本地方法区(Native Method Area):本地方法区是用于存储本地方法的内存区域。
- PC寄存器(Program Counter Register):PC寄存器是用于存储当前执行线程的指令地址的寄存器。
数组是如何开辟出一块内存的?
public static void main(String[] args){
int[] arr = new int[2];
System.out.println(arr);
System.out.println(arr[0]);
System.out.println(arr[1]);
}
两个数组指向同一个空间的内存图
public static void main(String[] args){
int[] arr1 = {11,22};
int[] arr2 = arr1;
System.out.println(arr1[0]);
System.out.println(arr2[0]);
}
输出结果
11
11
Java内存模型(JMM)定义了Java程序中线程之间的内存访问行为。JMM规定了以下几个概念:
- 主内存(Main Memory):主内存是所有线程共享的内存区域,线程对主内存的读写操作必须通过同步操作进行。
- 本地内存(Local Memory):本地内存是线程私有的内存区域,不同线程之间的本地内存是隔离的,无法相互访问。
- 内存屏障(Memory Barrier):内存屏障是一种硬件指令,用于强制读取和写入内存的操作顺序。
- 原子性(Atomicity):原子性是指一个操作在执行过程中不会被其他操作干扰,要么完全执行成功,要么完全不执行。
- 可见性(Visibility):可见性是指一个线程对共享变量的修改对于其他线程来说是可见的。
- 有序性(Sequencing):有序性是指对于多个线程的读写操作,它们之间的执行顺序是有序的。