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

目录

​编辑

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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【网课必备】学浪视频下载到本地

学浪作为知识付费平台&#xff0c;拥有大量的课程&#xff0c;所以很多人在学浪上购买自己的课程&#xff0c;但是学浪官方没有提供下载选项&#xff0c;只可以在学浪客户端软件观看&#xff0c;并不是很方便 于是为了解决这一个需求&#xff0c;小白老师s开发了学浪视频下载到…

uniapp 开发之原生Android插件

开发须知 在您阅读此文档时&#xff0c;我们假定您已经具备了相应Android应用开发经验&#xff0c;使用Android Studio开发过Android原生。也应该对HTML,JavaScript,CSS等有一定的了解, 并且熟悉在JavaScript和JAVA环境下的JSON格式数据操作等。 为了插件开发者更方便快捷的开…

verdi出现的问题

仿真时Verdi出现的问题&#xff1a; User Defined system task or function ($fsdbDumpfile) registered during elaboration and used within the simulation has not been registered during simulation. 解决方法&#xff1a;在run脚本中加上以下设置 又遇到如下问题&#x…

基于kmeans的聚类微博舆情分析系统

第一章绪论 1.1研究背景 如今在我们的生活与生产的每个角落都可以见到数据与信息的身影。自从上十世纪八十年代的中后期开始&#xff0c;我们使用的互联网技术已经开始快速发展&#xff0c;近些年来云计算、大数据和物联网等与互联网有相领域的发展让互联网技术达到了史无前例…

揭秘阿里巴巴面试题:JVM垃圾回收存活算法和两次标记过程

大家好,我是你们的小米。今天我们来聊聊一个热门话题,那就是阿里巴巴的面试题:JVM垃圾回收存活算法和两次标记过程。作为一个热爱技术、乐于分享的小米,我将会带领大家一起深入探讨这个话题。 引用计数法 首先,我们来了解一下引用计数法。这是一种简单直观的垃圾回收算法…

备战蓝桥杯---刷杂题1

1.来个小定理&#xff08;上次DP的青蛙过河用过&#xff09; 事实上&#xff0c;假如他们的gcd&#xff01;1,那么P,q都可以表示成gcd的倍数&#xff0c;因此假如一个数不是gcd的倍数就不可以表示&#xff0c;若互质由裴蜀定理大于一定时一定可以表示出。 事实上为&#xff08…

关于 QSound播放wav音频文件,播放失败“using null output device, none available” 的解决方法

若该文为原创文章&#xff0c;转载请注明原文出处 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/137264493 红胖子(红模仿)的博文大全&#xff1a;开发技术集合&#xff08;包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软…

GaussDB云数据库极简版安装与使用-新手指南

一、前言 作为一款领先的企业级数据库管理系统&#xff0c;GaussDB 提供了强大的性能、高度可靠性和丰富的功能&#xff0c;是企业构建可靠、高性能的数据库解决方案的理想选择。 本文主要针对高校和个人测试环境&#xff0c;介绍极简版安装和使用过程&#xff0c;更加适合高…

护眼台灯哪个牌子好?护眼台灯品牌排行前十名推荐

台灯可以说家家必备的一盏灯具&#xff0c;如果家长有正在上学的孩子的更需要一款好的台灯&#xff0c;因为不管是看书、写字、阅读都离不开台灯的帮助&#xff0c;而且一款好的台灯不仅仅能够提供明亮充足的照明环境&#xff0c;而且还能起到保护视力健康&#xff0c;预防近视…

echarts实现炫酷科技感的流光效果

前言&#xff1a; echarts实现炫酷科技感的流光效果 效果图&#xff1a; 实现步骤&#xff1a; 1、引入echarts,直接安装或者cdn引入 npm i echarts https://cdn.jsdelivr.net/npm/echarts5.4.3/dist/echarts.min.js 2、封装 option方法&#xff0c;第一个数据是折线数据&a…

互联网轻量级框架整合之JavaEE基础I

不得不解释得几个概念 JavaEE SUN公司提出来的企业版Java开发中间件&#xff0c;主要用于企业级互联网系统的框架搭建&#xff0c;同时因为Java语言优质的平台无关性、可移植性、健壮性、支持多线程和安全性等优势&#xff0c;其迅速成为构建企业互联网平台的主流技术&#x…

AI预测福彩3D第24弹【2024年4月2日预测--第4套算法重新开始计算第10次测试】

今天继续对第4套算法进行测试&#xff0c;因为第4套算法已连续多期命中&#xff0c;相对来说还算稳定。好了&#xff0c;废话不多说了&#xff0c;直接上预测的结果吧~ 2024年4月2日福彩3D的七码预测结果如下 第一套&#xff1a; 百位&#xff1a;1 2 …

旅游管理系统|基于Springboot的旅游管理系统设计与实现(源码+数据库+文档)

旅游管理系统目录 目录 基于Springboot的旅游管理系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、用户管理 2、景点分类管理 3、景点信息管理 4、酒店信息管理 5、景点信息 6、游记分享管理 四、数据库设计 1、实体ER图 2、具体的表设计如下所示&#xf…

【MySQL】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)

前言 大家好吖&#xff0c;欢迎来到 YY 滴MySQL系列 &#xff0c;热烈欢迎&#xff01; 本章主要内容面向接触过C Linux的老铁 主要内容含&#xff1a; 欢迎订阅 YY滴C专栏&#xff01;更多干货持续更新&#xff01;以下是传送门&#xff01; YY的《C》专栏YY的《C11》专栏YY的…

郭天祥新概念51单片机(第四期读书笔记)

时钟周期、状态周期、机器周期、指令周期与晶振频率之间的关系 1、晶振频率与脉冲的关系 假设单片机的晶振频率是12MHz&#xff0c;那么它的一个脉冲为1/12微秒&#xff1b;晶振单位时间发出的脉冲则为&#xff1a; 12 ∗ 1 0 6 12*10^6 12∗106。 假设单片机的晶振频率是4MH…

【微众银行笔试题汇总】 2024-03-31-微众银行春招笔试题-三语言题解(CPP/Python/Java)

&#x1f36d; 大家好这里是KK爱Coding &#xff0c;一枚热爱算法的程序员 ✨ 本系列打算持续跟新微众银行近期的春秋招笔试题汇总&#xff5e; &#x1f4bb; ACM银牌&#x1f948;| 多次AK大厂笔试 &#xff5c; 编程一对一辅导 &#x1f44f; 感谢大家的订阅➕ 和 喜欢&…

全流程基于GIS、python机器学习技术的地质灾害风险评价与信息化建库实践应用

将结合项目实践案例和科研论文成果进行讲解。入门篇&#xff0c;ArcGIS软件的快速入门与GIS数据源的获取与理解&#xff1b;方法篇&#xff0c;致灾因子提取方法、灾害危险性因子分析指标体系的建立方法和灾害危险性评价模型构建方法&#xff1b;拓展篇&#xff0c;GIS在灾害重…

鸿蒙 UIAbility和Compent 生命周期

一、UIAbility的生命周期 在UIAbility的使用过程中&#xff0c;会有多种生命周期状态&#xff0c;掌握UIAbility的生命周期&#xff0c;对于应用的开发非常重要。 1、UIAbility的生命周期 UIAbility的生命周期主要分为以下4个&#xff1a; Create---Foreground---Background---…

梨花带雨网页音乐播放器二开优化修复美化版全开源版本源码

源码简介 最新梨花带雨网页音乐播放器二开优化修复美化版全开源版本源码下载 梨花带雨播放器基于thinkphp6开发的XPlayerHTML5网页播放器前台控制面板,支持多音乐平台音乐解析。二开内容&#xff1a;修复播放器接口问题&#xff0c;把接口本地化&#xff0c;但是集成外链播放器…

一文读懂:设计顶尖用户体验的网站,必看!

在设计网站的过程中&#xff0c;我们需要发散思维&#xff0c;不仅要在脑海中构建丰富的网站原型框架&#xff0c;还要在我们面前实现。这种方法可以以最低的成本创造最大的效益&#xff0c;测试当前设计的实用性。它还可以测试用户对网站的想法和感受&#xff0c;全面判断网站…