Java——数组

数组是一块连续的内存,用来存储相同类型的数据

一、数组的定义

数组的创建
T[] 数组名 = new T[N];

T:表示数组中存放元素的类型

T[]:表示数组的类型

N:表示数组的长度

数组的初始化

数组的初始化主要分为动态初始化和静态初始化

动态初始化

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

T[] 数组名称 = new T[N];
静态初始化

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

T[] 数组名称 = {data1, data2, data3, ..., datan};

注意

  • 静态初始化虽然没有指定数组的长度,编译器在编译时会根据{}中元素个数来确定数组的长度。
  • 静态初始化时, {}中数据类型必须与[]前数据类型一致。
  • 静态初始化可以简写,省去后面的new T[]。虽然省去了new T[], 但是编译器编译代码时还是会还原
  • 静态和动态初始化也可以分为两步,但是省略格式不可以

int[] array1;
array1 = new int[10];
int[] array2;
array2 = new int[]{10, 20, 30};
// 注意省略格式不可以拆分, 否则编译失败
// int[] array3;
// array3 = {1, 2, 3};
  • 如果没有对数组进行初始化,数组中元素有其默认值

如果数组中存储元素类型为基类类型,默认值为基类类型对应的默认值

类型默认值
byte0
short0
int0
long0
float

0.0f

double0.0
char/u0000
booleanfalse

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

二、数组的使用

数组中元素访问

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

注意

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

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

遍历数组

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

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

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

int[] array = {1, 2, 3};for (int x : array) {  //遍历这个数组的时候吧数组中的元素进行赋值给XSystem.out.println(x);}

二者的区别:

for循环遍历数组的时候是有下标的,而for-each 没有

三、null

 

 

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

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

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

四、二维数组

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

public class Test{public static void main(String[] args) {//定义方式int[][] array1 = {{1,2,3},{4,5,6}};int[][] array2 = new int[][]{{1,2,3},{4,5,6}};int[][] array3 = new int[2][3];//行不能省略int[][] array4 = new int[2][]; //列可以省略,称为不规则二维数组}
}

打印二维数组

public class Test{public static void main(String[] args) {int[][] array = {{1,2,3},{4,5,6}};System.out.println(array[0][1]);System.out.println(array.length);//2System.out.println(array[0].length);//3System.out.println(array[1].length);//3for (int i = 0; i < array.length; i++) {for (int j = 0; j < array[i].length; j++) {System.out.print(array[i][j] + " ");}System.out.println();}
}

五、数组的应用场景

保存数据
public class Test{public static void main(String[] args) {int[] array = {1, 2, 3};for(int i = 0; i < array.length; ++i){System.out.println(array[i] + " ");}} 
}
作为函数的参数
public class Test{public static void main(String[] args) {int[] array = {1,2,3,4};/*分别调用fun1和fun2array会变为什么*///fun1(array);  //99 2 3 4fun2(array);  //1 2 3 4for (int x:array) {System.out.print(x+" ");}}public static void fun1(int[] array) {array[0] = 99;}public static void fun2(int[] array) {array = new int[]{11,22,33,44,55};  //只是修改了形参的指向}
}
作为函数的返回值
public class Test{public static void main(String[] args) {//数组作为函数的返回值int[] ret = func3();for (int i = 0; i < ret.length; i++) {System.out.println(ret[i]);}}public static int[] func3() {int[] ret = new int[2];ret[0] = 10;ret[1] = 100;return ret;}
}

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

链表基础4——带头双向循环链表

什么是带头双向循环链表 我们直接看图片 定义结点类型 typedef int LTDataType;//存储的数据类型typedef struct ListNode {LTDataType data;//数据域struct ListNode* prev;//前驱指针struct ListNode* next;//后继指针 }ListNode;链表的初始化 //创建一个新结点 ListNod…

社交媒体数据恢复:Dust

社交媒体数据恢复&#xff1a;Dust/CYBER DUST 网络灰尘&#xff1a;更安全的发短信场所 概述 CYBER DUST 让您掌控自己的数字生活。我们相信网络生活就是现实生活&#xff0c;因此只有您应该控制有关您的信息。我们的用户受到保护——不用担心被窥探、数据挖掘、粗略的黑客&…

Golang | Leetcode Golang题解之第42题接雨水

题目&#xff1a; 题解: func trap(height []int) (ans int) {n : len(height)if n 0 {return}leftMax : make([]int, n)leftMax[0] height[0]for i : 1; i < n; i {leftMax[i] max(leftMax[i-1], height[i])}rightMax : make([]int, n)rightMax[n-1] height[n-1]for i…

06 MapStream递归

Collections(集合工具类) 可变参数 就是一种特殊形参&#xff0c;定义在方法、构造器的形参列表里&#xff0c;定义格式是&#xff1a;方法名(数据类型… 形参名称){ } 可变参数的特点和好处 **特点&#xff1a;**可以不传数据给它&#xff1b;可以传一个或者同时传多个数据给…

Edge 浏览器使用方法和经验技巧

目前我已经将主力浏览器从火狐更换到Edge&#xff0c;本文将会根据我自己的使用经验来不断更新完善&#xff0c;内容包括下载、常用插件、使用技巧和常见问题等 下载安装 Edge是win10内置的浏览器&#xff0c;因此多数人不需要下载&#xff0c;如果你的电脑并没有安装&#x…

LearnOpenGL(二)之三角形

一、重要概念 顶点数组对象&#xff1a;Vertex Array Object&#xff0c;VAO顶点缓冲对象&#xff1a;Vertex Buffer Object&#xff0c;VBO元素缓冲对象&#xff1a;Element Buffer Object&#xff0c;EBO 或 索引缓冲对象 Index Buffer Object&#xff0c;IBO 以数组的形式…

《2024最新Java面试题及答案(带完整目录)》

2024最新Java面试题及答案有史以来见过的最全面试题 获取链接&#xff1a;《2024最新Java面试题及答案&#xff08;带完整目录&#xff09;》 更多技术书籍&#xff1a;技术书籍分享&#xff0c;前端、后端、大数据、AI、人工智能... ​ ​ ​ 4.1.9.8. 可重入锁&#xff…

【KMP】优质模板推荐+解读

KMP – y神模板 引言&#xff1a;由于本人与4月20日前周五的一节数据结构课中偶然听到了老师讲kmp这个算法的概念并且发现老师讲的听不懂一点儿导致异常难受&#xff0c;于是花了两天左右自行弄懂了kmp算法的逻辑&#xff0c;并写下本文以便以后复习&#xff0c;并作留念。 声明…

数据结构10:堆和堆排序

文章目录 树的概念及结构树的概念树的相关概念树的表示树在实际中的应用表示文件系统的目录树结构 二叉树概念及结构概念特殊的二叉树二叉树的性质二叉树的存储结构顺序存储链式存储 二叉树的顺序结构及实现二叉树的顺序结构堆的概念及结构 堆的实现堆的插入堆的删除堆的创建向…

8.1 二叉排序树 —— C语言实现

系列文章目录 参考船说系列——数据结构与算法中的第八章内容。 二叉排序树AVL树红黑树B-树 文章目录 系列文章目录前言一、二叉排序树基础二、二叉排序树的操作2.1 插入2.2 删除 三、代码演示总结参考文献 前言 数据结构 结构定义 结构操作 结构操作是用来维护结构性质的…

spring高级篇(二)

1、Aware和InitializingBean Aware和InitializingBean都与Bean的生命周期管理相关。 Aware接口: 概念: Aware接口是Spring框架中的一个标记接口&#xff0c;它表示一个类能够感知到&#xff08;aware of&#xff09;Spring容器的存在及其特定的环境。Spring框架提供了多个Awar…

自然语言处理基础面试

文章目录 TF-IDFbag-of-wordsBert 讲道理肯定还得有Transformer&#xff0c;我这边先放着&#xff0c;以后再加吧。 TF-IDF TF&#xff08;全称TermFrequency&#xff09;&#xff0c;中文含义词频&#xff0c;简单理解就是关键词出现在网页当中的频次。 IDF&#xff08;全称…