Java 数组在内存中的存储 数组的常见操作

Java 数组在内存中的存储 数组的常见操作Java 数组在内存中的存储数组的常见操作

Java虚拟机的内存划分

为了提高运算效率,就对空间进行了不同区域的划分,因为每一片区域都有特定的处理数据方式和内存管理方式。

  • JVM的内存划分:
区域名称 作用
寄存器 给CPU使用,和我们开发无关。
本地方法栈 JVM在使用操作系统功能的时候使用,和我们开发无关。
方法区 存储可以运行的class文件。
堆内存 存储对象或者数组,new来创建的,都存储在堆内存。
方法栈 方法运行时使用的内存,比如main方法运行,进入方法栈中执行。

数组在内存中的存储

一个数组内存图

public static void main(String[] args) { 
     int[] arr = new int[3]; System.out.println(arr);//[I@5f } 

两个数组内存图

public static void main(String[] args) { 
     int[] arr = new int[3]; int[] arr2 = new int[2]; System.out.println(arr); System.out.println(arr2); } 

在这里插入图片描述

两个变量指向一个数组

public static void main(String[] args) { 
     // 定义数组,存储3个元素 int[] arr = new int[3]; //数组索引进行赋值 arr[0] = 5; arr[1] = 6; arr[2] = 7; //输出3个索引上的元素值 System.out.println(arr[0]); System.out.println(arr[1]); System.out.println(arr[2]); //定义数组变量arr2,将arr的地址赋值给arr2 int[] arr2 = arr; arr2[1] = 9; System.out.println(arr[1]); } 

在这里插入图片描述

数组的常见操作

public static void main(String[] args) { 
     int[] arr = { 
    1,2,3}; System.out.println(arr[3]); } 

数组空指针异常

public static void main(String[] args) { 
     int[] arr = { 
    1,2,3}; arr = null; System.out.println(arr[0]);

arr = null 这行代码,意味着变量arr将不会在保存数组的内存地址,也就不允许再操作数组了,因此运行的时候
会抛出 NullPointerException 空指针异常。在开发中,数组的越界异常是不能出现的,一旦出现了,就必须要修
改我们编写的代码。

在这里插入图片描述


空指针异常在内存图中的表现
在这里插入图片描述

数组遍历

public static void main(String[] args) { 
      int[] arr = { 
      1, 2, 3, 4, 5 }; for (int i = 0; i < arr.length; i++) { 
      System.out.println(arr[i]); } } 

数组获取最大值元素

public static void main(String[] args) { 
      int[] arr = { 
      5, 15, 2000, 10000, 100, 4000 }; //定义变量,保存数组中0索引的元素 int max = arr[0]; //遍历数组,取出每个元素 for (int i = 0; i < arr.length; i++) { 
      //遍历到的元素和变量max比较 //如果数组元素大于max if (arr[i] > max) { 
      //max记录住大值 max = arr[i]; } } System.out.println("数组最大值是: " + max); } 

数组反转

在这里插入图片描述

public static void main(String[] args) { 
      int[] arr = { 
      1, 2, 3, 4, 5 }; /* 循环中定义变量min=0最小索引 max=arr.length‐1最大索引 min++,max‐‐ */ for (int min = 0, max = arr.length ‐ 1; min <= max; min++, max‐‐) { 
      //利用第三方变量完成数组中的元素交换 int temp = arr[min]; arr[min] = arr[max]; arr[max] = temp; } // 反转后,遍历数组 for (int i = 0; i < arr.length; i++) { 
      System.out.println(arr[i]); } } 

数组作为方法参数

  • 数组作为方法参数传递,传递的参数是数组内存的地址。
public static void main(String[] args) { 
      int[] arr = { 
      1, 3, 5, 7, 9 }; //调用方法,传递数组 printArray(arr); } /* 创建方法,方法接收数组类型的参数 进行数组的遍历 */ public static void printArray(int[] arr) { 
      for (int i = 0; i < arr.length; i++) { 
      System.out.println(arr[i]); } } 

在这里插入图片描述


数组作为方法返回值

  • 数组作为方法的返回值,返回的是数组的内存地址
 public static void main(String[] args) { 
       //调用方法,接收数组的返回值 //接收到的是数组的内存地址 int[] arr = getArray(); for (int i = 0; i < arr.length; i++) { 
       System.out.println(arr[i]); } } /* 创建方法,返回值是数组类型 return返回数组的地址 */ public static int[] getArray() { 
       int[] arr = { 
      1, 3, 5, 7, 9}; //返回数组的地址,返回到调用者 return arr; } 

在这里插入图片描述


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233681.html原文链接:https://javaforall.net

(0)
上一篇 2025年6月29日 下午8:01
下一篇 2025年6月29日 下午8:22


相关推荐

  • 大型电商网站架构案例和技术架构【推荐】

    大型电商网站架构案例和技术架构【推荐】大型网站架构是一个系列文档,欢迎大家关注。本次分享主题:电商网站架构案例。从电商网站的需求,到单机架构,逐步演变为常用的,可供参考的分布式架构的原型。除具备功能需求外,还具备一定的高性能,高可用,可伸缩,可扩展等非功能质量需求(架构目标)。根据实际需要,进行改造,扩展,支持千万PV,是没问题的。本次分享大纲电商案例的原因电商网站需求网站初级架构系统容量估算网站架构分析网站架构优化架构总结电商网站案…

    2022年6月16日
    34
  • 强大的nginx反向代理异步传输模式(原理)[通俗易懂]

    强大的nginx反向代理异步传输模式(原理)[通俗易懂]sudone.com在nginx的反向代理介绍中,提到了异步传输模式并提到它可以减少后端连接数和压力,这是为何?下面就来讲解下传统的代理(apache/squid)的同步传输和nginx的异步传输的差异。看图:         squid同步传输:浏览器发起请求,而后请求会立刻被转到后台,于是在浏览器和后台之间就建立了一个通道。在请求发起直到请求完成,这条通道都是一直存在的。nginx异步传输:浏…

    2025年11月13日
    8
  • 本地知识库+智谱开源GLM-Z1-Air,安全私密、回答速度飞快!效果突破新高度【含MCP玩法】

    本地知识库+智谱开源GLM-Z1-Air,安全私密、回答速度飞快!效果突破新高度【含MCP玩法】

    2026年3月12日
    1
  • 教程上新|GLM-Image基于自回归+扩散解码器混合架构,精准理解指令写对文字

    教程上新|GLM-Image基于自回归+扩散解码器混合架构,精准理解指令写对文字

    2026年3月12日
    3
  • 决策树原理解析_解析的原理

    决策树原理解析_解析的原理决策树原理解析1.决策树算法以及基本流程决策树是基于树结构进行决策的,其机制就是通过判定每个属性分类的纯度来进行自上而下决策分类决策树包含根结点,内部结点,叶结点;根结点和内部结点对应与分类的属性(也就是分类的基准),叶结点对应决策结果(也就是纯度很高且不需要继续分裂的类别);从根结点到某一个叶结点的路径便是当前叶结点对应类的整个决策过程,下面来看决策树的算法流程:可以看到决…

    2025年10月6日
    5
  • 算数平均数、中位数、众数和几何平均数[通俗易懂]

    算数平均数、中位数、众数和几何平均数[通俗易懂]文章目录算数平均数、中位数、众数和几何平均数算数平均数、中位数、众数和几何平均数统计数据时经常用到的几种数的比较:算数平均数中位数众数几何平均数英文名ArithmeticmeanMedianModeGeometricMean别称均值中值定义n个变量的和除以n。中位数是按顺序排列的一组数据中居于中间位置的数,即在这组数据中,有一半的…

    2025年12月15日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号