将未排序的数组传递给binarysearch是一种逻辑错误。爱这种情况下,binarysearch方法返回的值是不确定的。
类Arrays提供静态方法asList。将数组当做一个List的集合。其中封装了和链表相似的行为、
asList
public static <T> List<T> asList(T... a)
- 返回一个受指定数组支持的固定大小的列表。(对返回列表的更改会“直接写”到数组。)此方法同
Collection.toArray()
一起,充当了基于数组的 API 与基于 collection 的 API 之间的桥梁。返回的列表是可序列化的,并且实现了RandomAccess
。此方法还提供了一个创建固定长度的列表的便捷方法,该列表被初始化为包含多个元素:
List<String> stooges = Arrays.asList("Larry", "Moe", "Curly");
- 参数:
a
- 支持列表的数组。- 返回:
- 指定数组的列表视图。
- Arrays.asList创建一个固定大小的List,他的操作速度比任何已有的List的实现都要快。但是如果对其调用add或者remove方法将会抛出异常:UnsupportedOpterationException。
而且对asList的修改,会涉及到原来的数组。如下:
- package AsList;
- import java.util.Arrays;
- import java.util.List;
- public class AsList {
- private String[] num = { "blue", "red", "yellow" };
- private int[] data = { 1, 2, 3 };
- private List list;
- private List list1;
- public AsList() {
- list = Arrays.asList(num);
- list1 = Arrays.asList(data);
- }
- public void printnumber() {
- for (int i = 0; i < list1.size(); ++i)
- System.out.println(list1.get(i));
- for (int i = 0; i < list.size(); ++i)
- System.out.println(list.get(i));
- list.set(1, "green");
- for (int i = 0; i < list.size(); ++i)
- System.out.println(list.get(i));
- for (int i = 0; i < num.length; ++i)
- System.out.println(num[i]);
- }
- public static void main(String[] args) {
- new AsList().printnumber();
- }
- }
输出结果为:
[I@c17164
blue
red
yellow
blue
green
yellow
blue
green
yellow