Java数组的内存分配

Java数组的内存分配

  1. Java内存分为几个部分,分别是堆、栈、方法区、本地方法区、PC寄存器等。

    1. 堆(Heap):堆是Java中用于存储对象的和数组的内存区域,所有通过new操作符创建的对象都会在堆上分配内存。堆是一个动态分配的内存区域,大小可以根据程序需要自动调整。
    2. 栈(Stack):每个线程都会有一个自己的栈,用于存储方法调用和局部变量。当一个方法被调用时,一个新的栈帧会被创建并压入栈中,当方法返回时,栈帧被弹出。
    3. 方法区(Method Area):方法区是用于存储Java类信息、常量、静态变量、即时编译器编译后的代码等信息的内存区域。方法区与堆一样,是各个线程共享的内存区域。
    4. 本地方法区(Native Method Area):本地方法区是用于存储本地方法的内存区域。
    5. PC寄存器(Program Counter Register):PC寄存器是用于存储当前执行线程的指令地址的寄存器。

Java数组的内存分配_第1张图片

数组是如何开辟出一块内存的?

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]);
}

Java数组的内存分配_第2张图片

两个数组指向同一个空间的内存图

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数组的内存分配_第3张图片

Java内存模型(JMM)定义了Java程序中线程之间的内存访问行为。JMM规定了以下几个概念:

  1. 主内存(Main Memory):主内存是所有线程共享的内存区域,线程对主内存的读写操作必须通过同步操作进行。
  2. 本地内存(Local Memory):本地内存是线程私有的内存区域,不同线程之间的本地内存是隔离的,无法相互访问。
  3. 内存屏障(Memory Barrier):内存屏障是一种硬件指令,用于强制读取和写入内存的操作顺序。
  4. 原子性(Atomicity):原子性是指一个操作在执行过程中不会被其他操作干扰,要么完全执行成功,要么完全不执行。
  5. 可见性(Visibility):可见性是指一个线程对共享变量的修改对于其他线程来说是可见的。
  6. 有序性(Sequencing):有序性是指对于多个线程的读写操作,它们之间的执行顺序是有序的。

你可能感兴趣的:(java,开发语言,算法)