Arrays类

  1. Arrays里面包含了一系列静态方法,用于管理或操作数组(比如排序和搜索)

  2. 常用方法

    • toString 返回数组的字符串形式 Arrays.toString(arr)

      Integer[] integers = {1, 20, 90};
      System.out.println(Arrays.toString(integers)); //[1, 20, 90]
    • sort 排序(自然排序和定制排序)

      Integer arr[] = {1, -1, 7, 0, 89};
      //1. 因为数组是引用类型,所以通过sort排序后,会直接影响到 实参 arr
      //2. sort重载的,也可以通过传入一个接口 Comparator 实现定制排序
      //3. 调用 定制排序 时,传入两个参数 (1) 排序的数组arr
      // (2) 实现了Comparator接口的匿名内部类,要求实现 compare方法
      //4. 这里体现了接口编程的方式,看看源码,就明白
      // 源码分析
      // (1) Arrays.sort(arr, new Comparator()
      // (2) 最终到 TimSort类 private static <T> void binarySort(T[] a, int lo, int hi, int start,
      // Comparator<? super T> c)
      // (3) 执行到 binarySort 方法的代码,会根据动态绑定机制 c.compare()执行我们传入的
      // 匿名内部类的 compare()
      // while (left < right) {
      // int mid = (left + right) >>> 1;
      // if (c.compare(pivot, a[mid]) < 0)
      // right = mid;
      // else
      // left = mid + 1;
      // }
      // (4) new Comparator() {
      // @Override
      // public int compare(Object o1, Object o2) {
      // Integer i1 = (Integer)o1;
      // Integer i2 = (Integer)o2;
      // return i2 - i1;
      // }
      // }
      // (5) public int compare(Object o1, Object o2) 返回的值>0 还是 <0
      // 会影响整个排序结果
      //Arrays.sort(arr); // 默认排序
      //定制排序
      Arrays.sort(arr, new Comparator() {
      @Override
      public int compare(Object o1, Object o2) {
      Integer i1 = (Integer)o1;
      Integer i2 = (Integer)o2;
      return i1 - i2;
      }
      });
      System.out.println(Arrays.toString(arr));//[-1, 0, 1, 7, 89]
    • binarySearch 通过二分搜索法进行查找,要求必须排好序

      //1. 要求该数组是有序的,如果该数组是无序的,不能使用binarySearch
      //2. 如果数组中不存在该元素,就返回 return -(low + 1); low是如果存在,它应该在的位置
      Integer[] arr = {1, 2, 90, 123, 567};
      int index = Arrays.binarySearch(arr,2);
      System.out.println("index=" + index);
    • copyOf 数组元素的复制

      //1. 从 arr 数组中,拷贝 arr.length 个元素到 newArr数组中
      //2. 如果拷贝的长度 > arr.length 就在新数组的后面 增加 null
      //3. 如果拷贝长度 < 0 就抛出异常NegativeArraySizeException
      //4. 该方法的底层使用的是 System.arraycopy()
      Integer[] newArr = Arrays.copyOf(arr,arr.length);
    • fill 数组元素的填充

      //1. 使用 99 去填充 num数组,可以理解成是替换原来的元素
      Integer[] num = new Integer[]{9, 3, 2};
      Arrays.fill(num,99);
      System.out.println(Arrays.toString(num)); //[99, 99, 99]
    • equals 比较两个元素内容是否完全一致

      //1. 如果arr 和 arr2 数组的元素一样,则方法返回true
      //2. 如果不是完全一样,就返回false
      Boolean equals = Arrays.equals(arr,arr2);
      System.out.println("equals=" + equals); //equals=true
    • asList 将一组值,转换成list

      //1. asList方法,会将(2,3,4,5,6,1)数据转成一个List集合
      //2. 返回的 asList 编译类型 List(接口)
      //3. asList 运行类型 java.util.Arrays#ArrayList
      List asList = Arrays.asList(2,3,4,5,6,1);
      System.out.println("asList=" + asList);
      System.out.println("asList的运行类型" + asList.getClass());

6、Arrays类的更多相关文章

  1. 使用 Arrays 类操作 Java 中的数组

    Arrays 类是 Java 中提供的一个工具类,在 java.util 包中.该类中包含了一些方法用来直接操作数组,比如可直接实现数组的排序.搜索等(关于类和方法的相关内容在后面的章节中会详细讲解滴 ...

  2. Java Arrays类进行数组排序

    排序算法,基本的高级语言都有一些提供.C语言有qsort()函数,C++有sort()函数,java语言有Arrays类(不是Array).用这些排序时,都可以写自己的排序规则. Java API对A ...

  3. 慕课网-Java入门第一季-6-7 使用 Arrays 类操作 Java 中的数组

    来源:http://www.imooc.com/code/1556 Arrays 类是 Java 中提供的一个工具类,在 java.util 包中.该类中包含了一些方法用来直接操作数组,比如可直接实现 ...

  4. 数组 Arrays类

    1.数组是一组变量集合,用来存储相同数据类型的一组数据的连续的空间. *数组名(标识符)连续空间首地址. *元素下标标明元素在数组中的位置,从0开始. *每个元素都可以通过下标来访问. *数组长度固定 ...

  5. Java API ——Arrays类

    1.Arrays类概述 · 针对数组进行操作的工具类. · 提供了排序,查找等功能. 2.成员方法 · public static String toString(int[] a):in[] a可以改 ...

  6. Arrays 类操作 Java 的数组排序

    使用 Arrays 类操作 Java 中的数组 Arrays 类是 Java 中提供的一个工具类,在 java.util 包中.该类中包含了一些方法用来直接操作数组,比如可直接实现数组的排序.搜索等( ...

  7. java的Arrays类的应用

    (2012-08-01 14:48:27) 转载▼ 标签: java arrays类 填充 排序 查找 比较数组 分类: java基础 java.util.Arrays类能方便地操作数组,它提供的所有 ...

  8. java.util.Arrays类

    前言:java.util.Arrays类的技术文档请查看Oracle官网 1.Arrays类常见方法: 本文参考资料:百度文库:Oracle官网:第三方中文技术文档

  9. 【java】java.util.Arrays类常用方法

    package Arrays类; import java.util.Arrays; public class TestArrays { public static void main(String[] ...

  10. Java学习笔记26(Math类、Arrays类、BigInteger类、BigDecimal类)

    Math类:数学工具类,做一些数学计算,开方,对数,三角函数等 所有方法都是静态方法,不需要建立对象,直接用类名调用即可 示例: 这里写几个在日常开发中会用到的,比如三角函数之类的平时不会用到,了解即 ...

随机推荐

  1. 9.4 苹果macOS电脑如何安装Android开发环境(Android Studio)

    下载 来到官方下载界面(需要 科 学 上 网),下载最新版本,点击Download,然后同意协议,在点击下载:如果平常看文档,可以点击Google中国Android开发者官网(部分用户可能也需要科 学 ...

  2. NC16783 [NOIP1998]拼数

    NC16783 [NOIP1998]拼数 题目 题目描述 设有 \(n\) 个正整数(\(n ≤ 20\)),将它们联接成一排,组成一个最大的多位整数. 例如:\(n=3\) 时,\(3\) 个整数 ...

  3. 阿里云有奖体验:用PolarDB-X搭建一个高可用系统

    体验简介 场景将提供一台配置了CentOS 8.5操作系统和安装部署PolarDB-X集群的ECS实例(云服务器).通过本教程的操作,带您体验如何使用PolarDB-X搭建一个高可用系统,通过直接ki ...

  4. 广西省行政村边界shp数据/广西省乡镇边界/广西省土地利用分类数据/广西省气象数据/降雨量分布数据/太阳辐射数据

    ​  数据下载链接:数据下载链接 广西壮族自治区,地处中国南部,北回归线横贯中部,属亚热带季风气候区.南北以贺州--东兰一线为界,此界以北属中亚热带季风气候区,以南属南亚热带季风气候区. 数据范围:全 ...

  5. Tapdata 实时数据融合平台解决方案(一):现代企业数据架构及痛点

    作者介绍:TJ,唐建法,Tapdata 钛铂数据 CTO,MongoDB中文社区主席,原MongoDB大中华区首席架构师,极客时间MongoDB视频课程讲师. "怎样可以来搭建一个数据中台? ...

  6. $\mathcal{A\,F\,O}$

    突然间,告诉我不用学计算机了 真的有点像是做梦 回忆自己的OI生涯 真的不知从何说起 小学的时候 被家长哄着报名了当时很热门的 logo语言 在炎热的夏天,电脑里小海龟的步伐从未停歇 那时的自己很骄傲 ...

  7. led的进化

    1.一个led亮100ns,灭400ns,循环 2.一个led亮2500ns,灭5000ns,亮7500ns,灭10000ns循环 3.以2500ns为变化周期,20000ns为一个循环,每个周期的亮 ...

  8. 算法竞赛进阶指南 0x50 总论

    目录 AcWing895. 最长上升子序列 方法一 方法二 当询问最长子序列是哪些的时候 896. 最长上升子序列 II 思路 O(NlogN)做法:贪心+二分 代码 AcWing\897. 最长公共 ...

  9. 一篇文章带你走进meta viewport的世界

    一.什么是 meta 标签? 可提供有关页面的元信息 二.为什么需要移动端适配? 因为我们在 pc 端上看到的页面都是比较大的,在 pc 端上都是正常显示的,自动不会被进行缩放,除非手动进行放大或缩小 ...

  10. 2535-springsecurity系列--关于授权角色“ROLE”前缀的问题

    版本信息 <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring ...