1、创建数组的三种方式:

①动态初始化:数组的初始化和数组元素的赋值操作分开进行

  dataType[ ] arrayRefVar = new dataType [ arraySize ] ;

            Emp [] emps=new Emp[3];
Emp emp1=new Emp(null,"a1",12,"0");
Emp emp2=new Emp(null,"aa2",13,"1");
Emp emp3=new Emp(null,"aaa3",14,"0");
emps[0]=emp1;
emps[1]=emp2;
emps[2]=emp3;

②类型推断:  dataType[ ] arrayRefVar = { value1,value2,..., valueN };

            Emp emp1 = new Emp(null, "a", 23, "男");
Emp emp2 = new Emp(null, "aa", 23, "男");
Emp emp3 = new Emp(null, "aaa", 23, "男");
Emp[] emps = {emp1, emp2, emp3};

③静态初始化:数组的初始化和数组元素的赋值操作同时进行

  dataType[ ] arrayRefVar = new dataType [ ] {value1,value2,..., valueN };

            Emp emp11=new Emp(8,"sdh",133,"1");
Emp emp22=new Emp(9,"sds",134,"0");
Emp[] emps11 = new Emp[] {emp11,emp22};

总结:有且总有一个体现元素个数的位置

2、数组的特点:
  ①数组是序排列的
  ②数组属于引用数据类型的变量。数组的元素,既可以是基本数据类型,也可以是引用数据类型
  ③创建数组对象会在内存中开辟一整块连续的空间
  ④数组的长度一旦确定,就不能修改。
3、数组的分类:
  ① 维数:一维数组、二维数组、。。。
  ② 数组元素的类型:基本数据类型元素的数组、引用数据类型元素的数组

4、一维数组元素的默认初始化值
  > 数组元素是整型:0
  > 数组元素是浮点型:0.0
  > 数组元素是char型:0或'\u0000',而非'0'
  > 数组元素是boolean型:false
  > 数组元素是引用数据类型:null

5、数组常见的异常类型

  ①.数组角标越界异常:ArrayIndexOutOfBoundsException

  ②.空指针异常:NullPointerException

二维数组的声明与初始化
正确的方式:   int[] arr = new int[]{1,2,3};//一维数组
//静态初始化
int[][] arr1 = new int[][]{{1,2,3},{4,5},{6,7,8}};
//动态初始化1
String[][] arr2 = new String[3][2];
//动态初始化2
String[][] arr3 = new String[3][];
   //也是正确的写法:
int[] arr4[] = new int[][]{{1,2,3},{4,5,9,10},{6,7,8}};
int[] arr5[] = {{1,2,3},{4,5},{6,7,8}};//类型推断

二维数组元素的默认初始化值
 *  规定:二维数组分为外层数组的元素,内层数组的元素
 *   int[][] arr = new int[4][3];
 *   外层元素:arr[0],arr[1]等
 *   内层元素:arr[0][0],arr[1][2]等
 *
 *   数组元素的默认初始化值
 *   针对于初始化方式一:比如:int[][] arr = new int[4][3];
 *      外层元素的初始化值为:地址值
 *      内层元素的初始化值为:与一维数组初始化情况相同
 *     
 *   针对于初始化方式二:比如:int[][] arr = new int[4][];
 *    外层元素的初始化值为:null
 *      内层元素的初始化值为:不能调用,否则报错。

Arrays 类

java.util.Arrays 类能方便地操作数组,它提供的所有方法都是静态的。

具有以下功能:

  • 给数组赋值:通过 Arrays.fill 方法。
  • 对数组排序:通过 Arrays.sort 方法,按升序。
  • 比较数组:通过 Arrays.equals 方法比较数组中元素值是否相等。
  • 查找数组元素:通过 Arrays.binarySearch 方法能对排序好的数组进行二分查找法操作
  • 将数组变成字符串(public static String toString(数组))Arrays.toString()

Java数组和Arrays 类的更多相关文章

  1. Java数组05——Arrays类

    Arrays类讲解  package array; ​ import java.util.Arrays; ​ public class ArrayDemon07 {     public static ...

  2. java数组中Arrays类

    使用Arrays类之后要先导入包,即在开头添加这行: import.java.util.Arrays 1,排序:Arrays.sort(数组名) 排序后为数组升序. 2,将数组转换成字符串:Array ...

  3. Java常用API(Arrays类)

    Java常用API(Arrays类) 什么是Arrays类? java.util.Arrays 此类包含用来操作数组的各种方法,比如排序和搜索等.其所有方法均为静态方法,调用起来 非常简单. 这里我们 ...

  4. Java数组声明创建和使用以及多维数组、Arrays类、稀疏数组

    目录 数组概述 数组声明创建 内存分析 java内存分析 堆 栈 方法区 三种初始化 静态初始化 动态初始化 数组的默认初始化 数组的四个基本特点 数组边界 小结: 数组使用 数组基础使用 For E ...

  5. jdk1.8 对数组及arrays类对数组的操作与增强

    数组的初始化有两种方式 静态初始化: 初始化时由程序员显示置顶每个数组的初始值,由系统决定数组长度.如: int[] a1 = new int[] {1,2,3,4}; 动态初始化:初始化时由程序员只 ...

  6. Java基础 【Arrays 类的使用】

    package com.zuoyan.sort; import java.util.Arrays; public class ArraysClassDemo { public static void ...

  7. Java中的Arrays类使用详解

    首先先创建一个打印数组的方法,方便后面直接使用 public static void output(int []a) { for(int i=0;i<a.length;i++) { System ...

  8. java中的Arrays类

    今天刚接触了数组,学到了几个比较常用的方法 Fill方法:给数组赋值 sort方法:给数组升序 equals方法:比较数组中元素 值是否相等 binarySearch方法:对排序好的数组进行二分查找法 ...

  9. [java初探05]__数组的简单认识及Arrays类的常用方法

    数组是具有相同数据类型的一组数据的集合.在程序设计中,这样的集合称之为数组.数组的每个元素都具有相同的数据类型,在Java中数组也被看为一个对象. 在里,了解了数组的定义之后, 我们知道了,数组并不是 ...

随机推荐

  1. Linux ubuntu下docker容器安装和基础命令

    Docker介绍: 云计算就好比大货轮,docker就是集装箱虚拟机虽然可以隔离出很多"子电脑",但占用空间更大,启动更慢,虚拟机软件可能还要花钱(例如VMWare). 而容器技术 ...

  2. Linux的Docker安装教程

    Docker下载的官方文档地址:https://docs.docker.com/engine/install/centos/ 卸载旧版本 sudo yum remove docker \ docker ...

  3. 如何实现 antd table 自动调整可视高度(纵向滚动条,scrollY)

    一.事情的起因 最近在做的项目中有大量的表格,正常的表格高度是没有限制的,数据量很大的时候会出现表格内容以及分页信息超出可视窗口, 为了查看超出的部分就需要滚动页面但是这样就会把查询条件等信息滚出可视 ...

  4. 攻防世界-MISC:gif

    这是攻防世界新手练习区的第七题,题目如下: 点击下载附件1,得到一个压缩包,解压后得到一些图片 嗯,黑白相间(又是懵逼的时候),又跑去看WP了,说是打开文件出现多个黑白,让人联想到二进制,白色图片代表 ...

  5. 动态SQL常用标签

    动态 SQL 目的:为了摆脱在不同条件拼接 SQL 语句的痛苦 在不同条件在生成不同的SQL语句 本质上仍然是SQL语句,不过是多了逻辑代码去拼接SQL,只要保证SQL的正确性按照格式去排列组合 可以 ...

  6. umi框架应用服务端SSR,实现数据预渲染

    当我们的应用使用服务端渲染的方式时,可能需要把初始化加载的数据例如推荐等不需要用户输入的内容直接渲染获取,也有利于SEO. 上一篇已经实现服务端渲染,本次实现服务端获取数据后在做渲染. 利用getIn ...

  7. 修复Arch Linux和Manjaro Linux无法显示emoji的问题

    安装好Arch Linux或Manjaro Linux系统后默认没办法正常显示emoji,通常会变成方框或者带有unicode码的方块: 这是因为缺失字体以及相关的字体配置导致的. 当然也有一小部分应 ...

  8. 简述Web3.0

    什么是 Web 3.0 以及为什么要关心它. 为了更好地理解什么是 Web 3.0,我们需要知道什么是 Web 1.0 和 2.0. 为了不让你厌烦,这里简单的解释一下: Web 1.0 -- 信息仅 ...

  9. 896.Montonic Array - LeetCode

    Question 896. Monotonic Array Solution 题目大意: 类似于数学中的减函数,增函数和物理中的加速度为正或为负 思路: 先比较前两个是大于0还是小于0,如果等于0就比 ...

  10. 167. Two Sum II - Input array is sorted - LeetCode

    Question 167. Two Sum II - Input array is sorted Solution 题目大意:和Two Sum一样,这里给出的数组是有序的 思路:target - nu ...