一、Arrays简介

Arrays是针对数组的工具类,可以进行 排序,查找,复制填充等功能。 大大提高了开发人员的工作效率。

二、Arrays提供的数组复制方法

使用System.arraycopy进行数组复制类似的, Arrays提供了一个copyOfRange方法进行数组复制。

不同的是System.arraycopy,需要事先准备好目标数组,并分配长度。 copyOfRange 只需要源数组就就可以了,通过返回值,就能够得到目标数组了。

除此之外,需要注意的是 copyOfRange 的第3个参数,表示源数组的结束位置,是取不到的

import java.util.Arrays;

public class HelloWorld {

public static
void main(String[] args) {

int a[] = new
int[] { 18, 62, 68, 82, 65, 9 };

// copyOfRange(int[] original, int from, int to)

// 第一个参数表示源数组

// 第二个参数表示开始位置(取得到)

// 第三个参数表示结束位置(取不到)

int[] b = Arrays.copyOfRange(a, 0, 3);

for (int i = 0; i < b.length; i++) {

System.out.print(b[i] + " ");

}

}

}

三、Arrays提供的转换为字符串方法

如果要打印一个数组的内容,就需要通过for循环来挨个遍历,逐一打印

但是Arrays提供了一个toString()方法,直接把一个数组,转换为字符串,这样方便观察数组的内容

import java.util.Arrays;

public class HelloWorld {

public static
void main(String[] args) {

int a[] = new
int[] { 18, 62, 68, 82, 65, 9 };

String content = Arrays.toString(a);

System.out.println(content);

}

}

四、Arrays提供的排序方法

之前完成了选择法排序 和 冒泡法排序,Arrays工具类提供了一个sort方法,只需要一行代码即可完成排序功能。

import java.util.Arrays;

public class HelloWorld {

public static
void main(String[] args) {

int a[] = new
int[] { 18, 62, 68, 82, 65, 9 };

System.out.println("排序之前 :");

System.out.println(Arrays.toString(a));

Arrays.sort(a);

System.out.println("排序之后:");

System.out.println(Arrays.toString(a));

}

}

五、Arrays提供的查询元素位置的方法

查询元素出现的位置

需要注意的是,使用binarySearch进行查找之前,必须使用sort进行排序(注:亲测,使用binarySearch进行查找之前,不必用sort排序)

如果数组中有多个相同的元素,查找结果是不确定的

import java.util.Arrays;

public class HelloWorld {

public static
void main(String[] args) {

int a[] = new
int[] { 18, 62, 68, 82, 65, 9 };

Arrays.sort(a);

System.out.println(Arrays.toString(a));

//使用binarySearch之前,必须先使用sort进行排序

System.out.println("数字 62出现的位置:"+Arrays.binarySearch(a, 62));

}

}

六、Arrays提供的判断数组元素是否相同的方法

比较两个数组的内容是否一样

第二个数组的最后一个元素是8,和第一个数组不一样,所以比较结果是false

import java.util.Arrays;

public class HelloWorld {

public static
void main(String[] args) {

int a[] = new
int[] { 18, 62, 68, 82, 65, 9 };

int b[] = new
int[] { 18, 62, 68, 82, 65, 8 };

System.out.println(Arrays.equals(a, b));

}

}

七、Arrays提供的填充数组元素的方法

使用同一个值,填充整个数组

import java.util.Arrays;

public class HelloWorld {

public static
void main(String[] args) {

int a[] = new
int[10];

Arrays.fill(a, 5);

System.out.println(Arrays.toString(a));

}

}

八、练习--二维数组排序

题目:

首先定义一个5X8的二维数组,然后使用随机数填充满。

借助Arrays的方法对二维数组进行排序。

参考思路:

先把二维数组使用System.arraycopy进行数组复制到一个一维数组

然后使用sort进行排序

最后再复制回到二维数组。

关于随机数

0-100的 随机整数的获取办法有多种,下面是参考办法之一:

(int) (Math.random() * 100)

Math.random() 会得到一个0-1之间的随机浮点数,然后乘以100,并强转为整型即可。

官方示例代码:

import java.util.Arrays;

public class HelloWorld {

public static
void main(String[] args) {

int a[][] = new
int[5][8];

for (int i = 0; i < a.length; i++) {

for (int j = 0; j < a[i].length; j++) {

a[i][j] = (int) (Math.random() * 100);

}

}

System.out.println("打印二维数组");

for (int[] i : a) {

System.out.println(Arrays.toString(i));

}

// 把二维数组复制到一维数组

int b[] = new
int[a.length * a[0].length];

for (int i = 0; i < a.length; i++) {

System.arraycopy(a[i], 0, b, i * a[i].length, a[i].length);

}

// 对一维数组进行排序

Arrays.sort(b);

// 把一维数组复制到二维数组

for (int i = 0; i < a.length; i++) {

System.arraycopy(b, a[i].length * i, a[i], 0, a[i].length);

}

System.out.println("打印排序后的二维数组");

for (int[] i : a) {

System.out.println(Arrays.toString(i));

}

}

}

Java知识系统回顾整理01基础06数组07数组工具类Arrays的更多相关文章

  1. Java知识系统回顾整理01基础06数组01创建数组

    一.数组定义 定义:数组是一个固定长度的,包含了相同类型数据的 容器 二.声明数组 int[] a; 声明了一个数组变量. []表示该变量是一个数组 int 表示数组里的每一个元素都是一个整数 a 是 ...

  2. Java知识系统回顾整理01基础06数组06二维数组

    一.一维数组和二维数组 这是一个一维数组, 里面的每一个元素,都是一个基本类型int int a[] =new int[]{1,2,3,4,5}; 这是一个二维数组,里面的每一个元素,都是一个一维数组 ...

  3. Java知识系统回顾整理01基础06数组03排序

    一.选择法排序 选择法排序的思路: 把第一位和其他所有的进行比较,只要比第一位小的,就换到第一个位置来 比较完后,第一位就是最小的 然后再从第二位和剩余的其他所有进行比较,只要比第二位小,就换到第二个 ...

  4. Java知识系统回顾整理01基础06数组02初始化数组

    一.分配空间与赋值分步进行 分配空间与赋值分步进行 public class HelloWorld { public static void main(String[] args) { int[] a ...

  5. Java知识系统回顾整理01基础06数组05复制数组

    数组的长度是不可变的,一旦分配好空间,是多长,就多长,不能增加也不能减少 一.复制数组 把一个数组的值,复制到另一个数组中 System.arraycopy(src, srcPos, dest, de ...

  6. Java知识系统回顾整理01基础06数组04增强型for循环

    增强型for循环在遍历一个数组的时候会更加快捷 一.增强型for循环 注:增强型for循环只能用来取值,却不能用来修改数组里的值 public class HelloWorld { public st ...

  7. Java知识系统回顾整理01基础04操作符06三元运算符

    一.三元运算符 表达式?值1:值2 如果表达式为真 返回值1 如果表达式为假 返回值2 if语句学习链接:if语句 public class HelloWorld { public static vo ...

  8. Java知识系统回顾整理01基础03变量06变量的作用域

    一.变量根据所处的位置对应不同的名称 变量处于不同的位置,有不同的名称 名称分别是  字段,属性 参数 局部变量 不同名称的变量,其作用域是不一样的 二.字段,属性,Field 当一个变量被声明在类下 ...

  9. Java知识系统回顾整理01基础04操作符01算术操作符

    一.算数操作符类别 基本的有: + - * / % 自增 自减: ++ -- 二.基本算数操作符 + - * / 基本的加 减 乘 除 public class HelloWorld { public ...

随机推荐

  1. 浅谈 FTP、FTPS 与 SFTP

    无论是网盘还是云存储,上传都是一项很简单的操作.那些便捷好用的上传整理工具所用的 FTP 协议到底是什么意义,繁杂的模式又有何区别? 二狗子最近搭建了一个图片分享网站,每天都有好多人在他的网站上传许多 ...

  2. 总结一篇shell调试技巧及常见的脚本错误

      #常见的调试命令工具 1.使用bash命令参数调试 #使用 [root@game ~]# sh [-xvn] test.sh #参数解释: -x:将执行的脚本内容输出出来,可以看到执行的过程 -n ...

  3. PHP弱类型hash比较缺陷

    成因分析: == 在进行比较的时候,会先将两边的变量类型转化成相同的,再进行比较 0e在比较的时候会将其视作为科学计数法,所以无论0e后面是什么,0的多少次方还是0. 因此CTF比赛中需要用到弱类型H ...

  4. 分享一个后端专用login模板

    给大家啊分享一个后端专用login模板 Java工程师再也不用这样啦---> html源码 <html lang="en"> <head> <m ...

  5. dya49:django:wsgrief&模板渲染Jinjia2&django的MTV/MVC框架&创建/启动一个django项目

    目录 1.自定义web框架wsgiref版 2.自定义web框架wsgiref版-优化版 3.模板渲染JinJa2 4.MTV和MVC框架 5.django:下载安装&创建启动 自定义web框 ...

  6. 在Nginx里指定ip_hash的方式解决Tomcat集群session的问题

    据称,Tomcat集群session同步方案有以下几种方式: 1)使用tomcat自带的cluster方式,多个tomcat间自动实时复制session信息,配置起来很简单.但这个方案的效率比较低,在 ...

  7. Java的foreach用法

    foreach其实就是for的加强版,其语法如下: for(元素类型type 元素变量value : 遍历对象obj) { 引用x的java语句; } 举个例子,比如定义一个数组,使用foreach以 ...

  8. 来讲讲你对ThreadLocal的理解

    前言 面试的时候被问到ThreadLocal的相关知识,没有回答好(奶奶的,现在感觉问啥都能被问倒),所以我决定先解决这几次面试中都遇到的高频问题,把这几个硬骨头都能理解的透彻的说出来了,感觉最起码不 ...

  9. Ubuntu更换国内源--解决终端下载速度慢的问题

    目前我已知的更改国内源的方法基本上就两种,第一种,把/etc/apt/sources.list文件里的源更换一下,改成阿里云或者其它源.第二种,更换在设置中software&updates(软 ...

  10. Linux:apache第一个简单的站点

    前提: apache安装目录再/application/apache/ 1.先进入安装目录中 cd /application/apache/ ls 查看目录中的内容 可以看到好多我们常见的文件夹,bi ...