java学习之路-数组定义与使用

news2025/1/15 19:58:19

目录

​编辑

1.什么是数组

2.数组的创建及其初始化

2.1数组的创建

2.2数组的初始化

3.数组的使用

3.1数组元素访问

 3.2遍历数组

 4.数组是引用类型

4.1jvm的内存分布

4.2基本类型变量与引用类型变量的区别

4.3引用变量详解

4.4 null

 5.数组的使用场景

5.1存储数据

5.2作为函数的参数

5.3作为函数的返回值

6.数组的练习

6.1数组转字符串

6.2数组的拷贝

6.3查找数组中指定元素(二分查找)

 7.二维数组

7.1二维数组的创建

7.2二维数组的遍历


1.什么是数组

数组:可以看成是相同类型元素的一个集合。在内存中是一段连续的空间。

在java中,包含6个整形类型元素的数组

1. 数组中存放的元素其类型相同

2. 数组的空间是连在一起的

3. 每个空间有自己的编号,其实位置的编号为0,即数组的下标。

2.数组的创建及其初始化

2.1数组的创建

T[] 数组名 = new T[N];
T:表示数组中存放元素的类型
T[]:表示数组的类型
N:表示数组的长度

三种创建方式

int[] array1 = new int[10];       
// 创建一个可以容纳10个int类型元素的数组
int[] array2 = {1,2,3};//直接初始化
int[] array3 = new int[]{1,2,3};

2.2数组的初始化

动态初始化:在创建数组时,直接指定数组中元素的个数。

int[] array = new int[10];

静态初始化:在创建数组时不直接指定数据元素个数,而直接将具体的数据内容进行指定

 int[] array1 = new int[]{0,1,2,3,4,5,6,7,8,9};
 double[] array2 = new double[]{1.0, 2.0, 3.0, 4.0, 5.0};
 String[] array3 = new String[]{"hell", "Java", "!!!"};

【注意事项】

静态初始化虽然没有指定数组的长度,编译器在编译时会根据{}中元素个数来确定数组的长度。

静态初始化时, {}中数据类型必须与[]前数据类型一致。

静态初始化可以简写,省去后面的new T[]。

推荐下面这个传初始化方式

int[] array1;
 array1 = new int[10];
 int[] array2;
 array2 = new int[]{10, 20, 30};

如果没有对数组进行初始化,数组中元素有其默认值。

如果数组中存储元素类型为引用类型,默认值为null.

3.数组的使用

3.1数组元素访问

数组在内存中是一段连续的空间,空间的编号都是从0开始的,依次递增,该编号称为数组的下标,数组可以通过 下标访问其任意位置的元素。

int[]array = new int[]{10, 20, 30, 40, 50};
 System.out.println(array[0]);
 System.out.println(array[1]);
 System.out.println(array[2]);
 System.out.println(array[3]);
 System.out.println(array[4]);
 
// 也可以通过[]对数组中的元素进行修改
 array[0] = 100;
 System.out.println(array[0]);

1. 数组是一段连续的内存空间,因此支持随机访问,即通过下标访问快速访问数组中任意位置的元素

2. 下标从0开始,介于[0, N)之间不包含N,N为元素个数,不能越界,否则会报出下标越界异常。

 3.2遍历数组

"遍历" 是指将数组中的所有元素都访问一遍, 访问是指对数组中的元素进行某种操作

 int[]array = new int[]{10, 20, 30, 40, 50};
 for(int i = 0; i < array.length; i++){
    System.out.println(array[i]);
 }

可以使用 for-each 遍历数组

 int[] array = {1, 2, 3};
 for (int x : array) {
    System.out.println(x);
 }

for-each 是 for 循环的另外一种使用方式. 能够更方便的完成对数组的遍历. 可以避免循环条件和更新语句写错。

 4.数组是引用类型

4.1jvm的内存分布

内存是一段连续的存储空间,主要用来存储程序运行时数据的。

1. 程序运行时代码需要加载到内存
2. 程序运行产生的中间数据要存放在内存
3. 程序中的常量也要保存
4. 有些数据可能需要长时间存储,而有些数据当方法运行结束后就要被销毁

上图是JVM对所使用的内存按照功能的不同进行了划分。

程序计数器 (PC Register): 只是一个很小的空间, 保存下一条执行的指令的地址

虚拟机栈(JVM Stack): 与方法调用相关的一些信息,每个方法在执行时,都会先创建一个栈帧,栈帧中包含 有:局部变量表、操作数栈、动态链接、返回地址以及其他的一些信息,保存的都是与方法执行时相关的一 些信息。比如:局部变量。当方法运行结束后,栈帧就被销毁了,即栈帧中保存的数据也被销毁了。

本地方法栈(Native Method Stack): 本地方法栈与虚拟机栈的作用类似. 只不过保存的内容是Native方法的局 部变量. 在有些版本的 JVM 实现中(例如HotSpot), 本地方法栈和虚拟机栈是一起的

堆(Heap): JVM所管理的最大内存区域. 使用 new 创建的对象都是在堆上保存 (例如前面的 new int[]{1, 2, 3} ),堆是随着程序开始运行时而创建,随着程序的退出而销毁,堆中的数据只要还有在使用,就不会被销 毁。

方法区(Method Area): 用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数 据. 方法编译出的的字节码就是保存在这个区域

4.2基本类型变量与引用类型变量的区别

基本数据类型创建的变量,称为基本变量,该变量空间中直接存放的是其所对应的值;

而引用数据类型创建的变量,一般称为对象的引用,其空间中存储的是对象所在空间的地址。

public static void func() {
    int a = 10;
    int b = 20;
//a、b是内置类型的变量,因此其空间中保存的就是给该变量初始化的值。
    int[] arr = new int[]{1,2,3};
//array是数组类型的引用变量,其内部保存的内容可以简单理解成是数组在堆空间中的首地址。
 }

引用变量并不直接存储对象本身,可以简单理解成存储的是对象在堆中空间的起始地址。通过该 地址,引用变量便可以去操作对象。有点类似C语言中的指针,但是Java中引用要比指针的操作更简单。

4.3引用变量详解

栗子

 public static void func() {
    int[] array1 = new int[3];
    array1[0] = 10;
    array1[1] = 20;
    array1[2] = 30;
 
    int[] array2 = new int[]{1,2,3,4,5};
    array2[0] = 100;
    array2[1] = 200;
 
    array1 = array2;
    array1[2] = 300;
    array1[3] = 400;
    array2[4] = 500;
    for (int i = 0; i < array2.length; i++) {
       System.out.println(array2[i]);
    }
 }

4.4 null

null 在 Java 中表示 "空引用" , 也就是一个不指向对象的引用

int[] arr = null;
 System.out.println(arr[0]);
 // 执行结果
Exception in thread "main" java.lang.NullPointerException
 at Test.main(Test.java:6)

null 的作用类似于 C 语言中的 NULL (空指针), 都是表示一个无效的内存位置. 因此不能对这个内存进行任何读写操 作. 一旦尝试读写, 就会抛出 NullPointerException.

注意: Java 中并没有约定 null 和 0 号地址的内存有任何关联

 5.数组的使用场景

5.1存储数据

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

5.2作为函数的参数

参数传基本数据类型

 public static void main(String[] args) {
    int num = 0;
    func(num);
    System.out.println("num = " + num);
 }
 
public static void func(int x) {
    x = 10;
    System.out.println("x = " + x);
 }
 
// 执行结果
x = 10
 num = 0

参数传数组类型(引用数据类型)

public static void main(String[] args) {
    int[] arr = {1, 2, 3};
    func(arr);
    System.out.println("arr[0] = " + arr[0]);
 }
 
public static void func(int[] a) {
    a[0] = 10;
    System.out.println("a[0] = " + a[0]);
 }
 
// 执行结果
a[0] = 10
 arr[0] = 10

在func方法内部修改数组的内容, 方法外部的数组内容也发生改变. 因为数组是引用类型,按照引用类型来进行传递,是可以修改其中存放的内容的。

5.3作为函数的返回值

获取斐波那契数列的前N项

public class TestArray {
    public static int[] fib(int n){
        if(n <= 0){
            return null;
        }
 
        int[] array = new int[n];
        array[0] = array[1] = 1;
        for(int i = 2; i < n; ++i){
            array[i] = array[i-1] + array[i-2];
        }
 
        return array;
    }
 
    public static void main(String[] args) {
        int[] array = fib(10);
        for (int i = 0; i < array.length; i++) {
            System.out.println(array[i]);
        }
    }
 }

6.数组的练习

6.1数组转字符串

import java.util.Arrays
 
int[] arr = {1,2,3,4,5,6};
 
String newArr = Arrays.toString(arr);
 System.out.println(newArr);
 
// 执行结果
[1, 2, 3, 4, 5, 6]

6.2数组的拷贝

    //数组拷贝
    public static void Copy(){
        int[] arr3 = {5,6,1,4,5};
        //第一种直接遍历数组赋值拷贝
        /*int[] tem = new int[arr3.length];
        for (int i = 0 ;i < arr3.length ; i ++){
            tem[i] = arr3[i];
        }
        System.out.println(Arrays.toString(tem));*/

        //第二种使用Arrays使用
        /*int[] copy2 = Arrays.copyOf(arr3,arr3.length);//参数是要拷贝的数组,拷贝的长度
        System.out.println(Arrays.toString(copy2));*/
        /*int[] copy3 = Arrays.copyOfRange(arr3,0,3);//指定范围拷贝[0,3)
        System.out.println(Arrays.toString(copy3));*/
        int[] copy4 = new int[arr3.length];
        //还能指定下标位置,然后设置拷贝范围
        System.arraycopy(arr3,1,copy4,1,arr3.length-1);
        System.out.println(Arrays.toString(copy4));
    }

6.3查找数组中指定元素(二分查找)

针对有序数组, 可以使用更高效的二分查找.

以升序数组为例, 二分查找的思路是先取中间位置的元素, 然后使用待查找元素与数组中间元素进行比较:

如果相等,即找到了返回该元素在数组中的下标

如果小于,以类似方式到数组左半侧查找

如果大于,以类似方式到数组右半侧查找

 public static void main(String[] args) {
    int[] arr = {1,2,3,4,5,6};
    System.out.println(binarySearch(arr, 6));
 }
 
public static int binarySearch(int[] arr, int toFind) {
    int left = 0; 
    int right = arr.length - 1;
    while (left <= right) {
 int mid = (left + right) / 2;
        if (toFind < arr[mid]) {
            // 去左侧区间找
            right = mid - 1;
        } else if (toFind > arr[mid]) {
            // 去右侧区间找
            left = mid + 1;
        } else {
            // 相等, 说明找到了
            return mid;
        }
    }
    // 循环结束, 说明没找到
    return -1;
 }
 

 7.二维数组

二维数组本质上也就是一维数组, 只不过每个元素又是一个一维数组

7.1二维数组的创建

//二维数组的定义,首先要明白,二维数组是特殊的一维数组
        int[][] arr = {{12,2,3},{2,2,3}} ;
        int[][] arr2 = new int[][]{{12,2,3},{2,2,3}};
        //int[][] arr3 = new int[2][3]{{12,2,3},{2,2,3}};//这样写是报错的,因为如果你赋值了,            //java会识别数组的大小的
        int[][] arr3 = new int[2][3];
        int[][] arr4 = new int[2][];//不规则二维数组,就是列是可以不同的

二维数组是特殊的一维数组

        System.out.println(arr.length);
        System.out.println(arr[0].length);
        System.out.println(arr[1].length);

7.2二维数组的遍历

        //遍历二维数组
        for (int i = 0 ; i < arr.length; i ++){//arr.lenth代表着中国二位数组的大小行数
            for (int j = 0; j < arr[i].length ; j ++){//arr[i].lenth代表着数组每行有几列。
                System.out.print(arr[i][j] + " ");
            }
            System.out.println();
        }
        //用加强版for来打印二维数组
        for (int[] tmp : arr){
            for(int x : tmp){
                System.out.print(x + " ");
            }
            System.out.println();
        }
        //简单粗暴的打印二维数组
        System.out.println(Arrays.deepToString(arr));
        //处理一下不规则二维数组
        arr4[0] = new int[]{1,2};
        arr4[1] = new int[]{1,2,3};
        System.out.println(Arrays.deepToString(arr4));
       int arr6[] = {1, 2, 3};
        System.out.println(Arrays.toString(arr6));

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1565371.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于SpringBoot+微信小程序的图书借阅管理系统(包运行调试)

介绍 系统介绍 是一套图书借阅管理系统&#xff0c;包括用户小程序以及后台管理系统。 前台商城系统包含用户注册登录、首页门户、图书查询、在线借阅、个人中心、我的信息、我的借阅、押金充值。 后台管理系统包含统计分析、用户管理、分类管理、图书管理、借阅管理、管理员…

硬件了解 笔记

motherboard的高低端区别在哪里&#xff1f; 核心&#xff1a;从单核变成双核&#xff0c;多核&#xff08;几核就是几个打工人&#xff09; 多线程&#xff1a;6核本来对应6个线程&#xff0c;但是多线程就是说6核对应12个线程 频率 主频&#xff1a;平时打工的速度 睿频&…

图书馆信息管理系统(项目测试)

图书馆管理系统系统分析与设计 图书馆信息管理系统&#xff08;项目需求和计划、项目设计&#xff09; 图书馆信息管理系统&#xff08;项目实现&#xff09; 图书馆信息管理系统&#xff08;项目测试&#xff09; 图书馆信息管理系统&#xff08;总&#xff09; 目录 一、项目…

【SQL Server】1. 认识+使用

1. 创建数据库的默认存储路径 C:\ProgramData\Microsoft\Windows\Start Menu\Programs\Microsoft SQL Server 2008 R2 当我们选择删除数据库时&#xff0c;对应路径下的文件也就删除了 2. 导入导出数据工具的路径 3. 注册数据库遇到的问题 ??? 目前的问题就是服务器新建…

赛氪网在长沙宣布启动“徽文化外宣翻译大赛”

2024年3月30日下午&#xff0c;在美丽的星城长沙&#xff0c;赛氪网作为承办方&#xff0c;在中国翻译协会年会期间成功举办了备受瞩目的“AI科技时代竞赛与就业分论坛”。此次论坛汇聚了众多翻译界、科技界和教育界的专家学者&#xff0c;共同就科技、实践、就业与竞赛人才培养…

LabVIEW齿轮箱噪声监测系统

LabVIEW齿轮箱噪声监测系统 齿轮箱作为机械设备的“心脏”&#xff0c;其健康状态对设备的性能有着重要的影响。传统的齿轮箱监测方法依赖于直接的振动信号分析&#xff0c;但这种方法不仅成本高昂&#xff0c;而且在安装和拆卸过程中可能对设备造成损害。针对这些问题&#x…

在 Langchain 中使用 RAPTOR 实现高级 RAG

RAPTOR&#xff1a;树结构的索引和检索系统的递归抽象处理-CSDN博客 原文地址&#xff1a;implementing-advanced-rag-in-langchain-using-raptor 2024 年 3 月 24 日 RAPTOR 简介 递归抽象处理树组织检索(RAPTOR)是种全新而强大的索引和检索技术&#xff0c;它全面适用于L…

基于springboot的实习生管理系统

文章目录 项目介绍主要功能截图&#xff1a;部分代码展示设计总结项目获取方式 &#x1f345; 作者主页&#xff1a;超级无敌暴龙战士塔塔开 &#x1f345; 简介&#xff1a;Java领域优质创作者&#x1f3c6;、 简历模板、学习资料、面试题库【关注我&#xff0c;都给你】 &…

SV学习笔记(二)

接口 什么是接口&#xff1f; 接口 主要用作验证 &#xff0c;国外有些团队会使用sv进行设计&#xff0c;那么接口就会用作设计。验证环境中&#xff0c;接口可以 使连接变得简洁而不易出错 。interface和module的使用性质很像&#xff0c; 可以定义端口&#xff0c;也可以定…

【单片机家电产品--晶闸管】

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 单片机家电产品–晶闸管 前言 记录学习单片机家电产品内容 已转载记录为主 一、知识点 晶体管和晶闸管之间的区别 晶体管和晶闸管之间的区别 什么是可控硅&#xff08;…

观察和配置MAC地址表

目录 原理概述 实验目的 实验内容 实验拓扑 ​编辑1&#xff0e;基本配置 2.观察正常状态时的MAC地址表 4.配置静态MAC地址表项 原理概述 MAC 地址表是交换机的一个核心组成部分&#xff0c;交换机主要是根据 MAC 地址表来进行帧的转发的。交换机对帧的转发操作行为一共有…

Linux 命令 top 详解

1 top命令介绍 Linux系统中&#xff0c;Top命令主要用于实时运行系统的监控&#xff0c;包括Linux内核管理的进程或者线程的资源占用情况。这个命令对所有正在运行的进程和系统负荷提供不断更新的概览信息&#xff0c;包括系统负载、CPU利用分布情况、内存使用、每个进程的内容…

Golang Context是什么

一、这篇文章我们简要讨论Golang的Context有什么用 1、首先说一下Context的基本作用&#xff0c;然后在讨论他的实现 (1)数据传递&#xff0c;子Context只能看到自己的和父Context的数据&#xff0c;子Context是不能看到孙Context添加的数据。 (2)父子协程的协同&#xff0c;比…

c++的学习之路:9、STL简介与string(1)

一、STL 1、什么是STL STL(standard template libaray-标准模板库)&#xff1a;是C标准库的重要组成部分&#xff0c;不仅是一个可复用的组件库&#xff0c;而且是一个包罗数据结构与算法的软件框架。 也就是说STL就是一个模板&#xff0c;这个模板就是整合了很多库让我们方…

磁盘如何分配数据数据

&#x1f4dd;个人主页&#xff1a;五敷有你 &#x1f525;系列专栏&#xff1a;算法分析与设计 ⛺️稳中求进&#xff0c;晒太阳 磁盘如何分配数据 数据切割&#xff1a; 按照固定长度进行切割---》编码翻译&#xff08;常用&#xff09; 计算机要求按照8bit(字节)进…

【蓝桥杯练习】tarjan算法求解LCA

还是一道比较明显的求LCA(最近公共祖先)模型的题目,我们可以使用多种方法来解决该问题&#xff0c;这里我们使用更好写的离线的tarjan算法来解决该问题。 除去tarjan算法必用的基础数组&#xff0c;我们还有一个数组d[],d[i]记录的是每个点的出度&#xff0c;也就是它的延迟时间…

学习Python第十五天:第一个程序python程序

第一个程序&#xff1a;ZIP文件口令破解机 编写ZIP文件口令破解机要从学习zipfile库的使用方法着手&#xff0c;打开pythn解释器&#xff0c;我们用help(zipfile)命令进一步了解这个库&#xff0c;并重点看一下zipfile类中的extractall()方法&#xff0c;这个类和这个方法对我…

在仿真环境中运行lio-sam

文章目录 前言LIO-SAM环境编译运行键盘控制编译lio-sam遇到的问题前言 Gazebo 仿真提供了一个高效且成本低廉的平台,使研究人员和开发者能够在安全且可控的虚拟环境中设计、测试和优化机器人系统。它允许快速原型制作和迭代,精确控制测试条件,并能模拟复杂或危险的场景,从…

2013年认证杯SPSSPRO杯数学建模B题(第二阶段)流行音乐发展简史全过程文档及程序

2013年认证杯SPSSPRO杯数学建模 B题 流行音乐发展简史 原题再现&#xff1a; 随着互联网的发展&#xff0c;流行音乐的主要传播媒介从传统的电台和唱片逐渐过渡到网络下载和网络电台等。网络电台需要根据收听者的已知喜好&#xff0c;自动推荐并播放其它音乐。由于每个人喜好…

【解决】Unity Profile | FindMainCamera

开发平台&#xff1a;Unity 2020.3.7f1c1 关键词&#xff1a;FindMainCamera   问题背景 ModelViewer 是开发者基于 UnityEngine 编写的相机控制组件。ModelView.Update 中调度52次并触发3次GC.Collect。显然并不期望并尽可能避免 Update 造成的GC 问题。事实上 FindMainCame…