详解 Arrays类
请关注本人博文——《详解 普通数组 —— Arrays类 与 浅克隆》
Arrays类:
概述:
针对数组进行操作的工具类。它提供了对于数组的值的排序、查找等功能。
现在,本人来展示一下Arrays类的常用API:
- public static List asList(T... a)
 
返回一个受指定数组支持的固定大小的列表。- public static String toString(int[] a)
 - public static void sort(int[] a)
 - public static int binarySearch(int[] a,int key)
 
这个方法的底层实现,就运用了二分查找的原理- static boolean equals(int[] a, int[] a2)
 
比较两个数组中的元素,是否一样- static int[] copyOf(int[] original, int newLength)
 
复制旧数组中的元素到一个新的数组中,新的数组长度是newLength 从0开始复制旧数组- static int[] copyOfRange(int[] original, int from, int to)
 
复制旧数组中的指定范围间的几个元素到新数组中
现在,本人来展示下Arrays类的其余API:
- static void sort(八大基本类型[] a)
 
对指定的 该数组按数字升序进行排序。- static void sort(Object[] a, int fromIndex, int toIndex)
 
根据元素的自然顺序对指定对象数组的指定范围按升序进行排序。- static < T > List< T > asList(T... a)
 
返回一个受指定数组支持的固定大小的列表。- static int binarySearch(八大基本类型[] a, 八大基本类型 key)
 
使用二分搜索法来搜索指定数组,以获得指定的值。- static int binarySearch(八大基本类型[] a, int fromIndex, int toIndex, 八大基本类型 key)
 
使用二分搜索法来搜索指定数组的范围,以获得指定的值。- static 八大基本类型[] copyOf(八大基本类型[] original, int newLength)
 
复制指定的数组,截取或用 0 填充(如有必要),以使副本具有指定的长度。- static T[] copyOf(T[] original, int newLength)
 
复制指定的数组,截取或用 null 填充(如有必要),以使副本具有指定的长度。- static <T,U> T[] copyOf(U[] original, int newLength, Class<? extends T[]> newType)
 
复制指定的数组,截取或用 null 填充(如有必要),以使副本具有指定的长度。- static <T,U> T[] copyOf(U[] original, int newLength, Class<? extends T[]> newType)
 
复制指定的数组,截取或用 null 填充(如有必要),以使副本具有指定的长度。- static 八大基本类型[] copyOfRange(八大基本类型[] original, int from, int to)
 
将指定数组的指定范围复制到一个新数组。- static T[] copyOfRange(T[] original, int from, int to)
 
将指定数组的指定范围复制到一个新数组。- static <T,U> T[] copyOfRange(U[] original, int from, int to, Class<? extends T[]> newType)
 
将指定数组的指定范围复制到一个新数组。- static boolean equals(Object[] a, Object[] a2)
 
如果两个指定的 Object[] 型数组彼此相等,则返回 true。- static String toString(八大基本类型[] a)
 
返回指定数组内容的字符串表示形式。
至于排序,在本人的《数据结构与算法》专栏中已经详细的讲解过了,所以,在这里,本人来介绍一下针对数组的查找手段——二分查找:
二分查找:
二分查找是有前提的:
前提:
数组已经排序好
二分查找的思想是:
思想:
将数组分为两半,让要目标值 与 中间的值作比较,比中间数大的话,就在中间数左边的序列中再这样查找;反之则在中间数右边的序列中这样查找
现在,我们来用代码简单实现下 二分查找:
private static int getIndex(int[] arr, int num) {
        //定义三个索引
        int minIndex = 0;
        int maxIndex = arr.length - 1;
        int centIndex = (minIndex + maxIndex) / 2;
        while (minIndex <= maxIndex) {
            if (num == arr[centIndex]) {
                return centIndex;
            } else if (num < arr[centIndex]) {
                maxIndex = centIndex - 1;
            } else if (num > arr[centIndex]) {
                minIndex = centIndex + 1;
            }
            //重新计算中间索引
            centIndex = (minIndex + maxIndex) / 2;
        }
        return -1;
    }
那么,本人在这里展示下Arrays类的使用:
package about_arrays;
import java.util.Arrays;
import java.util.List;
public class Test {
	public static void main(String[] args) {
		int[] array = new int[] {1, 3, 5, 7, 9, 11};
		List<Integer> list = Arrays.asList(1, 2, 5, 3, 4);
		for (int i = 0; i < list.size(); i++) {
			System.out.println(list.get(i));
		}
		int position = Arrays.binarySearch(array, 7);
		System.out.println("7在array数组中的下标为:" + position);
	}
}
那么,本人来展示下运行结果:

至于List,将在本人博文——《详解 List接口》讲到,希望大家多多支持!!!
(本人普通数组总集篇博文链接:https://www.cnblogs.com/codderYouzg/p/12416481.html)
详解 Arrays类的更多相关文章
- unity3D游戏开发之详解Animation类和Animator类
		
详解Animator类和Animation类 链接: http://wenku.baidu.com/link?url=SiaUYcdrNYjOYrWVDJSKGAYdJOntMTOhsVJtyBk2i ...
 - 【python进阶】详解元类及其应用1
		
前言 元类在python中是很重要的一部分,我将分两次去讲解元类及其应用,此篇为详解元类及其应用第一篇,下面开始今天的说明~~~ 1. 类也是对象 在⼤多数编程语⾔中,类就是⼀组⽤来描述如何⽣成⼀个对 ...
 - 【python进阶】详解元类及其应用2
		
前言 在上一篇文章[python进阶]详解元类及其应用1中,我们提到了关于元类的一些前置知识,介绍了类对象,动态创建类,使用type创建类,这一节我们将继续接着上文来讲~~~ 5.使⽤type创建带有 ...
 - Unity3D - 详解Quaternion类(二)
		
OK,不做引子了,接上篇Unity3D - 详解Quaternion类(一)走起! 四.Quaternion类静态方法 Quaternion中的静态方法有9个即:Angle方法.Dot方法.Euler ...
 - Unity3D - 详解Quaternion类(一)
		
一.简介 Quaternion又称四元数,由x,y,z和w这四个分量组成,是由爱尔兰数学家威廉·卢云·哈密顿在1843年发现的数学概念.四元数的乘法不符合交换律.从明确地角度而言,四元数是复数的不可交 ...
 - Kotlin——最详解的类(class)的使用
		
在任何一门面向对象编程的语言里,类(class)是非常基础.但也是非常重要的一项组成,通俗的说就是万般皆对象,而所说的对象就是我们生成的类.Kotlin也是如此,下面详细为大家介绍Kotlin中的类的 ...
 - IOC和AOP使用扩展之AOP详解实现类
		
摘要: “Depend on yourself” is what nature says to every man. Parents can help you. Teachers can hel ...
 - 详解 Collections类
		
(请关注 本人"集合总集篇"博文--<详解 集合框架>) 有的同学可能会有这样的疑问 -- Collections类也是集合吗? 答曰:非也! 那为什么要讲解这个类呢? ...
 - 详解 Paths类 与 Files类
		
在本篇博文中,本人主要讲解NIO 的两个核心点 -- 缓冲区(Buffer) 和 通道 (Channel)之一的 缓冲区(Buffer), 有关NIO流的其他知识点请观看本人博文<详解 NIO流 ...
 
随机推荐
- ruby中的try catch
			
1.在ruby中,try catch并不是用来进行异常处理的,而是一种程序流程结构,例如break,continue,go-to等 2.例如如下代码 def promptAndGet(prompt) ...
 - 向Hive中传入变量的方式
			
Hive向程序中传递变量的方式 暴力替换 字符串替换 正则替换 模板引擎 系统环境变量 shell环境变量:${env:varname} system系统变量:${system:varname} hi ...
 - PyTorch专栏(六): 混合前端的seq2seq模型部署
			
欢迎关注磐创博客资源汇总站: http://docs.panchuang.net/ 欢迎关注PyTorch官方中文教程站: http://pytorch.panchuang.net/ 专栏目录: 第一 ...
 - openssl生成rsa公私钥对并在java中使用
			
rsa著名的非对称加密算法,具体实现我也不是很清楚,大概先要了解一下密码学,有一定基础才能去看的东东,这里就先介绍怎么使用rsa为我们服务. 首先openssl这是个集成了众多加密算法的工具,它将这一 ...
 - 将Python执行代码打包成exe可执行文件
			
安装pyinstaller pip3 install pyinstaller 进入py文件目录,执行以下指令 pyinstaller -F -w <文件名.py>,-F代表生成可执行文件, ...
 - 宝塔phpmyadmin可能问题及解决方法
			
1. 端口问题检查宝塔phpmyadmin的默认端口888是否放行,和在服务器的安全组规则有没有添加888端口 2.phpmyadmin的php版本问题 在phpmyadmin的设置里的版本选择php ...
 - Python第三方包之离线安装
			
Python第三方包之离线安装 第一步 首先我们得从pypi上先下载要装的第三方包 https://pypi.org/ 第二步(因为下载下来的包可能需要其他包的依赖,那我们依旧要按照第一步再次下载) ...
 - Spring Boot整合Thymeleaf视图层
			
目录 Spring Boot整合Thymeleaf Spring Boot整合Thymeleaf 的项目步骤 Thymeleaf 语法详解 Spring Boot整合Thymeleaf Spring ...
 - CSS超链接样式,去除下划线等
			
控制超链接样式 链接的四种状态: a:link - 普通的.未被访问的链接 a:visited - 用户已访问的链接 a:hover - 鼠标指针位于链接的上方 a:active - 链接被点击的时刻 ...
 - STM32CubeMX的安装
			
1.下载STM32CubeMX 在ST的官方网站上下载STM32CubeMXXX软件的安装包. 下载的安装包如下图所示.双击SetupSTM32CubeMX-5.0.1.exe. 安装STM32Cub ...