Java 数组基础中必须要掌握的

简介: Java 数组基础中必须要掌握的

一、数组

1、什么是数组?

概念:数组是用来存储一批同种类型数据的内存区域(容器)。

例子:int[] arr = {20,40,80,90,100};


2、数组学到什么程度

cb5465a694904812344d9a293e60b19.png


3、怎么定义数组

1)静态初始化数组

概念:定义时直接给数组赋值

格式:数据类型[] 变量 = new 数据类型[]{元素1,元素2…元素n} 或

数据类型 变量[] = new 数据类型[]{元素1,元素2…元素n}

例子:int[] arr = new int[]{10,20,30}; 或 int[] arr = {10,20,30};


2)动态初始化数组

格式:数据类型[] 变量 = new 数据类型[元素个数] 或

数据类型 变量[] = new 数据类型[元素个数]

例子:int[] arr = new int[3];


3)动静态数组用法

(1)静态数组:已知当前元素值

初始化:开始必须有元素值


(2)动态数组:未知要存入元素

初始化:指定数组元素个数,后期赋值


4)数组操作

数组长度:length-1,数组元素计算是从0(个数>0)开始的


5)默认值

6630cca04628a1c5b1d1ccae4d5d035.png


4、循环遍历数组

案例:for循环

10f23b8bc92ee83ce21aadf19fdb569.png


public class HelloWorld {
    public static void main(String[] args) {
        int arr[] = {10,20,30};
        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }
    }
}

5、数组内存重点

8fac3e686ed64f5b73d463b1e6a7c61.png

总结:

mian是入口存放方法区

变量存放栈内存中,因为arr1和arr2的地址相同,指向的同一地址,所以元素个数和值也是相同的

数据存放堆内存中


6、数组错误案例

案例一:数组越界,因为数组元素是从0开始计算的,所以3个元素是arr1[0],arr1[1],arr1[2]

0c3c9903ee1ea483b895e639eadeca5.png

案例二:空指针异常,数组元素存放是根据存放地址找到的,没有相关地址

0529e37db7deb4bceff7787a02f48d3.png

相关文章
|
7天前
|
存储 前端开发 JavaScript
【前端学java】一篇文章带你精通java 中的数组(10)
【8月更文挑战第10天】一篇文章带你精通java 中的数组
9 3
【前端学java】一篇文章带你精通java 中的数组(10)
|
7天前
|
Java 索引
java中的栈(利用数组实现栈)
这篇文章通过Java代码示例介绍了如何使用数组实现栈操作,包括栈的初始化、入栈、出栈、判断栈满和空以及遍历栈的方法。
java中的栈(利用数组实现栈)
|
12天前
|
Java
Java 基础语法-面试题(54-63道)(数组+类+包)
Java 基础语法-面试题(54-63道)(数组+类+包)
30 16
|
12天前
|
Java
Java数组几道练习题
Java数组几道练习题
27 11
|
12天前
|
Java 容器
07 Java数组与数组操作(定义+遍历+排序+增删改查)(上)
07 Java数组与数组操作(定义+遍历+排序+增删改查)
28 8
|
12天前
|
Java
Java数组的2个小案例(杨辉三角分析和商品管理增删改查)
Java数组的2个小案例(杨辉三角分析和商品管理增删改查)
37 4
|
12天前
|
存储 Java API
07 Java数组与数组操作(定义+遍历+排序+增删改查)(下)
07 Java数组与数组操作(定义+遍历+排序+增删改查)
26 4
|
6天前
|
Java
Java中 字符串,字符串数组,整型数组初始化
Java中 字符串,字符串数组,整型数组初始化
6 0
|
12天前
|
算法 Java 索引
LeetCode初级算法题:寻找数组的中心索引+x的平方根+三个数的最大乘积+Leetcode 149:直线上最多的点数 Java详解
LeetCode初级算法题:寻找数组的中心索引+x的平方根+三个数的最大乘积+Leetcode 149:直线上最多的点数 Java详解
23 0
|
12天前
|
存储 算法 Java
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
10 0