java.util.Arrays类

在java.util 中的Arrays 数组类容纳着一系列静态方法可简化我们对数组的操作,总共有四个函数。
sort()可对数组排序
binarySearch()用于在排好序的数组中查找一个元素。
equals()用于比较两个数组是否相等
fill()将一个值复制到一个位置,如果是对象数组则将引用复制到每一个位置。
asList()把数组转变成一个List 容器。
 
public static void sort(long[] a)
对指定的 long 型数组按数字升序进行排序。
   public static int binarySearch(long[] a,byte key)
 
   使用二分搜索法来搜索指定的 long 型数组,以获得指定的值。必须在进行此调用之前对数组进行排序(通过 sort(long[]) 方法)。如果没有对数组进行排序,则结果是不确定的。如果数组包含多个带有指定值的元素,则无法保证找到的是哪一个。
public static boolean equals(long[] a,long[] a2)
如果两个指定的 boolean 型数组彼此相等,则返回 true。如果两个数组包含相同数量的元素,并且两个数组中的所有相应元素对都是相等的,则认为这两个数组是相等的。换句话说,如果两个数组以相同顺序包含相同的元素,则两个数组是相等的。此外,如果两个数组引用都为 null,则认为它们是相等的。


public static void fill(Object[] a,int fromIndex,int toIndex,Object val)
 
将指定的 Object 引用分配给指定 Object 数组指定范围中的每个元素。填充的范围从索引 fromIndex(包括)一直到索引 toIndex(不包括)。
 
asList源代码
 
public static List asList(T... a) {
return new ArrayList(a);
    }
这里的ArrayList可不是我们常用的java.util.ArrayList,它是Arrays的一个内部类,继承自AbstractList
private static class ArrayList extends AbstractList
 implements RandomAccess, java.io.Serializable
    {
        private static final long serialVersionUID = -2764017481108945198L;
 private final E[] a;
 ArrayList(E[] array) {
             if (array==null)
                 throw new NullPointerException();
     a = array;
 }
         ......
    }
 
 这个类没有add方法,但是它的父类AbstractList有一个add方法
  public boolean add(E e) {
    add(size(), e);
    return true;
    }
    public void add(int index, E element) {
     throw new UnsupportedOperationException();
    }
    因为在Arrays类的内部类ArrayList只持有数组参数的一个引用,为避免改变原来的数组元素,这个ArrayList不允许执行add操作。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值