import java.util.Arrays;

int[] array1={7,8,3,2,12,6,5,4};

1.  //克隆clone 
int[] array2=array1.clone(); 
System.out.println("arry2克隆的结果是:"+Arrays.toString(array2));

2.  //复制copyof

①方法一:
int [] array3=Arrays.copyOf(array1, 4); // "4"表示复制的长度
System.out.println("arry3复制copyof的结果:"+Arrays.toString(array3));    //输出:[7,8,2,12]

②方法二:
System.arraycopy(src, srcPos, dest, destPos, length);
src -- 这是源数组.
srcPos -- 这是源数组中的起始位置。
dest -- 这是目标数组。
destPos -- 这是目标数据中的起始位置。
length -- 这是一个要复制的数组元素的数目。

异常:
    IndexOutOfBoundsException -- 如果复制会导致访问数组边界之外的数据
    ArrayStoreException -- 如果src数组中的元素不能被存储到dest数组中,因为类型不匹配
    NullPointerException -- 如果src或dest为null

例,
int arr1[] = { 0, 1, 2, 3, 4, 5 };
int arr2[] = { 11, 10, 20, 30, 40, 50 };
//从数组arr1中的第0个位置开始复制3个数,复制到arr2中,从b中的1位置开始存放
System.arraycopy(arr1, 0, arr2, 1, 3);   
System.out.println(Arrays.toString(arr2));  //输出:[11, 0, 1, 2, 40, 50]

3.判断两个数组是否相等:
        String[] a={"a","b","c"};
        String[] b={"a","b","c"};
        System.out.println(a.equals(b));//false
        System.out.println(a == b);//false
        System.out.println(Arrays.equals(a, b));//true

注意:

基本数据类型的数组的equals方法没有重载Object的equals方法,所以跟“==”效果一样 ,所以你这里 a.equals(b) 效果和 a == b是一样的,==比较的是内存地址,结果是false。
如果想要比较内容相同,可以使用Arrays.equals(a,b)。

4.  //对数组的第2个到第7个进行排序进行排序
Arrays.sort(array1,2,8);
System.out.print("对数组的第2个到第6个元素进行排序进行排序:Arrays.sort(array1,2,7):");
System.out.println(Arrays.toString(array1));

5.  //将arry1整体排序 sort  
Arrays.sort(array1);
//toString 转换为字符串
System.out.println("排序后的arry1的值:"+Arrays.toString(array1));

6. //排序后arry1与arry2是否还相等 equals  
System.out.println("排序后arry1与arry2是否还相等:"+Arrays.equals(array1, array2));

7. //填充 fill  
     Array.fill(arrayname,value);
     Array.fill(arrayname ,starting index ,ending index ,value)
例,
Arrays.fill(array3, 6);  //将数字6填充到数组array3,输出:{6,6,6,6,6,6,6,6}
Arrays.fill(array3, 2, 4, 9);  //将数组9从索引值2填充到索引值4
System.out.println("填充之后arry2的值:"+Arrays.toString(array3));//输出:{7,8,6,6,12,6,5,4}
 
8. //查询binarySearch
System.out.println("数字6在arry1中的位置:"+Arrays.binarySearch(array1, 6));

9. //将数组array1转换为List
        String[] name=new String[]{"a","b","c"};
        //转换为集合
        List<String> list=Arrays.asList(name);
        System.out.println(list);

10.数组的删除:
ArrayList<Integer> a = new ArrayList<Integer>();
for(int i=0;i<10;i++){
    a.add(i);
}
    a.remove(1);
        
System.out.println(a);   //输出:[0, 2, 3, 4, 5, 6, 7, 8, 9]

11.数组的查找:
①第一种方法:(这种方法需要用动态数组ArrayList)
ArrayList a = new ArrayList();
for(int i=0;i<10;i++){
    a.add(i);
}
a.remove(0);
System.out.println(a);   //输出:[1, 2, 3, 4, 5, 6, 7, 8, 9]
System.out.println(a.contains(1)); //返回boolea值      输出:true

②第二种方法:
int[] aa={1,2,3};
System.out.println("数字2在数组aa中的位置:"+Arrays.binarySearch(aa, 2));  //返回索引值  输出:1

注意:Java中Arrays的asList()方法 可以将数组转为List 但是,这个数组类型必须是引用类型,如果是8种基本数据类型就不可以!

JAVA中数组Arrays类的常见用法的更多相关文章

  1. JAVA中数组的基本概念与用法

    JAVA中数组的基本概念与用法 1. 数组的定义与特点 数组的一种引用数据类型 数组中可以同时存放多个数据,但是数据的类型必须统一 数组的长度在开始时就需要确定,在程序运行期间是不可改变的 虽然可以使 ...

  2. Java中数组Arrays.binarySearch,快速查找数组内元素位置

    在数组中查找一个元素,Arrays提供了一个方便查询的方法.Arrays.binarySearch(): 测试列子: public class MainTestArray { public stati ...

  3. Java中的Arrays类使用详解

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

  4. java中的Arrays类

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

  5. Java中数组的特性

    转载:http://blog.csdn.net/zhangjg_blog/article/details/16116613 数组是基本上所有语言都会有的一种数据类型,它表示一组相同类型的数据的集合,具 ...

  6. Java中的Unsafe类111

    1.Unsafe类介绍 Unsafe类是在sun.misc包下,不属于Java标准.但是很多Java的基础类库,包括一些被广泛使用的高性能开发库都是基于Unsafe类开发的,比如Netty.Hadoo ...

  7. 将java中数组转换为ArrayList的方法实例(包括ArrayList转数组)

    方法一:使用Arrays.asList()方法   1 2 String[] asset = {"equity", "stocks", "gold&q ...

  8. java 中常用的类

    java 中常用的类 Math Math 类,包含用于执行基本数学运算的方法 常用API 取整 l  static double abs(double  a) 获取double 的绝对值 l  sta ...

  9. java中数组以及集合

    java中数组: 数组在Java里是一种特殊类型,有别于普通的“类的实例”的对象.但实际数组也是一种对象类型,int[]a = new int[5]  a是在java栈中分配的引用变量,类型是int[ ...

随机推荐

  1. 盘点飞思卡尔i.MX多媒体处理器前世今生 (转)

    现如今,移动处理器领域,大家关注最多的是德州仪器.高通.展讯.MTK,甚至包括Intel,但是请别忘记飞思卡尔,他的i.MX处理器已经发展到第六代. 那么我们今天就来盘点下i.MX的前世今生吧. i. ...

  2. js如何展示上传的图片

    前言:本文章主要讲的是上传的图片如何展示在页面上. 一般来说,我们会先将本地图片上传到服务器,上传成功后,由后台返回图片的网络地址再在前端显示.但是,我今天讲的是不通过前面说的过程,而是直接使用js将 ...

  3. 利用python的requests和BeautifulSoup库爬取小说网站内容

    1. 什么是Requests? Requests是用Python语言编写的,基于urllib3来改写的,采用Apache2 Licensed 来源协议的HTTP库. 它比urllib更加方便,可以节约 ...

  4. os模块操作文件

    os模块: path=os.path.join(os.path.dirname(os.path.dirname(__file__)),'images') path:运行脚本的当前文件下的上一个文件的地 ...

  5. CSPS_103

    被sdfz踩爆了! %%%kai586123 %%%Gekoo %%%sdfz_yrt T1 我以为是水题!一直在肝! 而且为什么每次我的考场暴力都是考后才调出来啊!! 先记录一下正解的大神做法: 按 ...

  6. python学习之【第七篇】:Python中的集合及其所具有的方法

    1.前言 python中的集合set与列表类似,它们最大的区别是集合内不允许出现重复元素,如果在定义时包含重复元素,会自动去重. 集合是无序的,集合中的元素必须是不可变类型.集合可以作为字典的key. ...

  7. 「Usaco2012 Dec」第一(字典树+拓扑排序)

    (我恨字符串) 惯例化简题目:给定n个字符串,可以改变字符的相对大小(在字典序中的大小),问:字符串i是否能成为最小的字符串(字典序) 解题过程: 首先你可以预处理出来26的全排列然后暴力然后你只要用 ...

  8. win10系统任务栏点击没有反应

    今天碰到了一个神奇的bug任务栏上的图标怎么也没反应,鼠标点击不了,win+R命令行也出来不了. 经过一番研究,发现CTRL+ALT+DEL,可以打开任务管理器.所以来了一番操作: 1.先打开任务管理 ...

  9. Spring Cloud gateway 六 Sentinel nacos存储动态刷新

    微服务当前这么火爆的程度,如果不能学会一种微服务框架技术.怎么能升职加薪,增加简历的筹码?spring cloud 和 Dubbo 需要单独学习.说没有时间?没有精力?要学俩个框架?而Spring C ...

  10. 简述JMM

    一.很多初学者分不清JMM和JVM的内存模型,本篇只是简要的谈一谈什么是JMM,并不深入探讨. 示意图A: 在多线程操纵共享资源时,并不是对资源本身进行的操作,而是将共享资源的副本复制了一份到自己的私 ...