java 数组详细介绍

一.概述

  • 数组(Array),是多个相同类型数据一定顺序排列的集合,并使用一个名字命名,并通过编号的方式对这些数据进行统一管理
  • 数组常见概念: 数组名, 下标(或索引), 元素, 数组的长度
  • 数组本身是引用数据类型,而数组中的元素可以是任何数据类型,包括基本数据类型和引用数据类型
  • 创建数组对象会在内存中开辟一整块连续的空间,而数组名中引用的是这块连续空间的首地址
  • 数组的长度一旦确定,就不能修改
  • 可以直接通过下标(或索引)的方式调用指定位置的元素,速度很快
  • 数组的分类:
    • 按照维度: 一维数组、二维数组、三维数组、…
    • 按照元素的数据类型分: 基本数据类型元素的数组、引用数据类型元素的数组(即对象数组)

二.一维数组的使用

1.声明

type var[];type[] var;

例如: int a[]; int[] a; String[] b;

Java语言中声明数组时不能指定其长度(数组中元素的数), 例如: int a[5]; // 非法

2.初始化

  1. 动态初始化 :数组声明且为数组元素分配空间与赋值的操作分开进行

    int[] arr = new int[3];
    arr[0] = 3;
    arr[0] = 6;
    arr[0] = 9;
  2. 静态初始化 :在定义数组的同时就为数组元素分配空间并赋值
    int arr[] = new int[]{3,6,9};
    // 或
    int[] arr = {3,6,9};
    
    // 定义数组长度为0, 数组的长度可以为0
    int[] a = new int[]{};
    int[] a = {};

3.数组元素的引用

  • 定义并用运算符new为之分配空间后,才可以引用数组中的每个元素
  • 数组元素的引用方式:数组名[数组元素下标]
    • 数组元素下标可以是整型常量或整型表达式。如a[3] , b[i] , c[6*i]
    • 数组元素下标从0开始;长度为n的数组合法下标取值范围: 0 —> n-1
  • 每个数组都有一个属性length指明它的长度: 数组一旦初始化, 其长度是不可变的

4.元素默认初始化值

数组是引用类型,它的元素相当于类的成员变量,因此数组一经分配空间,其中的每个元素也被按照成员变量同样的方式被隐式初始化

数组元素类型 元素默认初始值
byte 0
short 0
int 0
long 0L
float 0.0F
double 0.0
char 0 或写为: ‘\u0000‘(表现为空)
boolean false
引用类型 null

5.示例

数组遍历:

// 数组的赋值和遍历输出
public class Test{
    public static void main(String args[]){
        int[] s;    // 局部变量:栈空间
        s = new int[10];    // 在堆内存为int[]对象分配空间,并隐式初始化为默认值
        //int[] s=new int[10];
        // 基本数据类型数组在显式赋值之前,自动赋默认值
        for ( int i=0; i<10; i++ ) {
            s[i] =2*i+1;    //显示初始化
            System.out.println(s[i]);   //输出
        }
    }
}

对象数组:

声明和初始化: 类名称[] 对象数组名称 = new 类名称[对象个数];

// 对象数组的使用
Student[] stu = new Student[10];
for(int i=0; i<stu.length; i++){
    Student s = new Student("Jack"+i,18+i);     //实例化对象
    stu[i] = s;    //将对象放入数组
}
for(int i=0; i<stu.length; i++){
    System.out.println(stu[i].name+" "+stu[i].age);     //打印输出每个对象的属性
}

三.二维数组的使用

对于二维数组(数组中的数组)的理解,我们可以看成是一维数组array1又作为另一个一维数组array2的元素而存在。其实,从数组底层的运行机制来看,其实没有多维数组

1.初始化

1.动态初始化: int[][] arr = new int[3][2];

  • 定义了名称为arr的二维数组
  • 二维数组中有3个一维数组
  • 每一个一维数组中有2个元素
  • 一维数组的名称分别为arr[0], arr[1], arr[2]
  • 给第一个一维数组1脚标位赋值为78写法是: arr[0][1] = 78;

2.动态初始化: int[][] arr = new int[3][]

  • 二维数组中有3个一维数组
  • 每个一维数组都是默认初始化值null
  • 可以对这个三个一维数组分别进行初始化
  • arr[0] = new int[3]; arr[1] = new int[1]; arr[2] = new int[2];

3.静态初始化: int[][] arr = new int[][]{{1,3,5},{2,4},{6,8,5,6}};
int[][] a = {(1,2,3),(4,5,6),(7,8,9)};

  • 定义一个名称为arr的二维数组,二维数组中有三个一维数组
  • 每一个一维数组中具体元素也都已初始化
  • 第一个一维数组arr[0] = {1,3,5};
  • 第二个一维数组arr[1] = {2,4};
  • 第三个一维数组arr[2] = {6,8,5,6};
  • 第三个一维数组的长度表示方式arr[2].length;
  • 注意特殊写法情况:int[] x,y[]; x是一维数组,y是二维数组

2.示例

二位数组的遍历:

String[][] s = new String[2][3];
for(int i=0; i<s.length; i++){    //s.length表示二维数组的行数
    for(int j=0; j<s[i].length; j++){    //s[i].length表示二维数组的列数
        s[i][j] = "第"+i+"行,第"+j+"列";    //将字符串对象存入数组
    }
}
//遍历输出二维数组的值  --嵌套循环
for(int i=0; i<s.length; i++){
    for(int j=0; j<s[i].length; j++){    //遍历每个一维数组
        System.out.print(s[i][j]+" ");
    }
    System.out.println();
}

不规则二维数组遍历:

// a.定义
int[][] a = new int[5][];    //定义行,即a[0]-a[4],a[i]都是数组对象的引用
a[0] = new int[4];    //定义a[0]所实际引用的数组对象,即第一行由4个元素组成
a[1] = new int[3];
a[2] = new int[1];
a[3] = new int[2];
//没有定义a[4],即第五行开辟的空间,没有显示初始化,a[4]默认值为null

// b.数组的遍历
for(int i=0; i<a.length; i++){
    System.out.print("第"+(i+1)+"行:");
    if(a[i] == null){   //判断数组对象的引用是否是null
        System.out.print(a[i]);
        continue;
    }
    for(int j=0; j<a[i].length; j++){
        System.out.print(a[i][j]+" ");
    }
    System.out.println();
}

四.常用两种排序

1.冒泡排序

// 定右边数字
int[] a = {1,3,2,6,4,8};
for(int i=0; i<a.length-1; i++){    //轮数
    for(int j=0; j<a.length-1-i; j++){  //次数
        if(a[j]>a[j+1]){
            int temp = a[j];
            a[j] = a[j+1];
            a[j+1] = temp;
        }
    }
}

2.选择排序

// 定左边数字
int[] flag = new int[2];    //中间容器
for(int i=0; i<a.length-1; i++){    //a.length轮只需要比较a.length-1轮
    flag[0] = a[i];
    flag[1] = i;
    for(int j=i+1; j<a.length; j++){    //比较最小值,放入中间容器
        if(a[i]>a[j]){
            flag[0] = a[j];
            flag[1] = j;
        }
    }
    if(flag[1] != i){    //换位置
        int temp = a[i];
        a[i] = flag[0];
        a[flag[1]] = temp;
    }
}

// 简单写法
int[] a = {1,3,2,6,4,8};
for(int i=0; i<a.length-1; i++){    //轮数
    for(int j=i+1; j<a.length; j++){    //次数
        if(a[i]>a[j]){
            int temp = a[i];
            a[i] = a[j];
            a[j] = temp
        }
    }
}

五.其它使用

1.Arrays工具类的使用

java.util.Arrays类即为操作数组的工具类,包含了用来操作数组(比如排序和搜索)的各种方法

方法 描述
boolean equals(int[] a,int[] b) 判断两个数组是否相等
String toString(int[] a) 输出数组信息
void fill(int[] a,int val) 将指定值填充到数组之中
void sort(int[] a) 对数组进行排序
int binarySearch(int[] a,int key) 对排序后的数组进行二分法检索指定的值

示例:

// 利用sort()方法对数组进行排序
import java.util.Arrays;
public class SortTest {
    public static void main(String[] args) {
        int[] numbers = {5,900,1,5,77,30,64,700};
        Arrays.sort(numbers);
        for(int i = 0; i < numbers.length; i++){
            System.out.println(numbers[i]);
        }
    }
}

2.数组使用中的常见异常

  1. 数组脚标越界异常(ArrayIndexOutOfBoundsException)

    // 访问到了数组中的不存在的脚标时发生
    int[] arr = new int[2];
    System.out.println(arr[2]);
  2. 空指针异常(NullPointerException)
    // arr引用没有指向实体,却在操作实体中的元素时
    int[] arr = null;
    System.out.println(arr[0]);

    ?

原文地址:https://www.cnblogs.com/itzlg/p/12024026.html

时间: 2024-08-01 13:43:49

java 数组详细介绍的相关文章

java agent 详细介绍 -javaagent参数

java agent 详细介绍 简介 java agent是java命令的一个参数.参数 javaagent 可以用于指定一个 jar 包,并且对该 java 包有2个要求: 这个 jar 包的MANIFEST.MF 文件必须指定 Premain-Class 项. Premain-Class 指定的那个类必须实现 premain()方法. 重点就在 premain 方法,也就是我们今天的标题.从字面上理解,就是运行在 main 函数之前的的类.当Java 虚拟机启动时,在执行 main 函数之前

JAVA HashMap详细介绍和示例

第1部分 HashMap介绍 HashMap简介 HashMap 是一个散列表,它存储的内容是键值对(key-value)映射. HashMap 继承于AbstractMap,实现了Map.Cloneable.java.io.Serializable接口. HashMap 的实现不是同步的,这意味着它不是线程安全的.它的key.value都可以为null.此外,HashMap中的映射不是有序的. HashMap 的实例有两个参数影响其性能:"初始容量" 和 "加载因子&quo

java线程详细介绍

目录(?)[-] 一扩展javalangThread类 二实现javalangRunnable接口 三Thread和Runnable的区别 四线程状态转换 五线程调度 六常用函数说明 使用方式 为什么要用join方法 七常见线程名词解释 八线程同步 九线程数据传递 本文主要讲了java中多线程的使用方法.线程同步.线程数据传递.线程状态及相应的一些线程函数用法.概述等. 首先讲一下进程和线程的区别: 进程:每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销,一个进程包含1

ACM中使用JAVA的详细介绍

0x01: Java的优缺点各种书上都有,这里只说说用Java做ACM-ICPC的特点: (1) 最明显的好处是,学会Java,可以参加Java Challenge . (2) 对于熟悉C/C++的程序员来说,Java 并不难学,找本书,一两周业余时间就可以搞定了.当然,这里只是指一般编程,想熟悉所有的Java库还是需要些时间的.事实上,Java 只相当于C++的一个改进版,所有的语法都几乎是C++的,很少有变动. (3) 在一般比赛中,Java程序会有额外的时间和空间,而实际上经过实验,在执行

Java ArrayList详细介绍和使用示例

对ArrayList的整体认识 ArrayList是一个数组队列,相当于动态数组.与Java中的数组相比,它的容量能动态增长.它继承了AbstractList,实现了List,RandomAccess,Cloneable,java.io.Serializable这些接口. ArrayList继承了AbstractList,实现了List.它是一个数组队列,提供了相关的添加.删除.修改.遍历等功能. ArrayList实现了RandomAccess接口,即提供了随机访问功能,RandomAcces

java内部类详细介绍

0.内部类与一般类有所不同,它是放在外部类的内部即可作为外部类的成员变量,也可放在方法内部作为局部变量,既然是变量,那么它可以用 private static 修饰符修饰,而外部类则不能,这也是内部类不同于一般java类的特殊之处. 1.分类:成员内部类 和 局部内部类 成员内部类: 静态成员变量: 创建方式:InnerClass inner = new OutClass.InnerClass(); 内部方法: 静态方法:只能访问外部类的静态变量: 普通方法:只能访问外部类的静态变量: 普通成员

Java NIO详细介绍

不错的文章,推荐一下. http://www.ibm.com/developerworks/cn/education/java/j-nio/j-nio.html JavaNIO非堵塞技术实际是采取Reactor模式,或者说是Observer模式为我们监察I/O端口,如果有内容进来,会自动通知我们,这样,我们就不必开启多个线程死等,从外界看,实现了流畅的I/O读写,不堵塞了 java nio的io模型是同步非阻塞,这里的同步异步指的是真正io操作(数据内核态用户态的拷贝)是否需要进程参与. 而说j

Java HashMap详细介绍和使用示例(正在整理学习中)

对HashMap的整体认识 HashMap是一个散列表,它存储的内容是键值对(key-value)映射. HashMap继承于AbstractMap,实现了Map.Cloneable.java.io.Serializable接口. HashMap的实现是不同步的,这意味着它不是线程安全的.它的key,value都可以是null.此外,HashMap中的映射不是有序的. https://www.cnblogs.com/skywang12345/p/3310835.html 原文地址:https:/

[转]详细介绍java中的数据结构

详细介绍java中的数据结构 本文介绍的是java中的数据结构,本文试图通过简单的描述,向读者阐述各个类的作用以及如何正确使用这些类.一起来看本文吧! 也许你已经熟练使用了java.util包里面的各种数据结构,但是我还是要说一说java版数据结构与算法,希望对你有帮助. 线性表,链表,哈希表是常用的数据结构,在进行Java开发时,JDK已经为我们提供了一系列相应的类来实现基本的数据结构.这些类均在java.util包中.本文试图通过简单的描述,向读者阐述各个类的作用以及如何正确使用这些类. C