1.ArrayList的遍历
ArrayList<Integer> list = new ArrayList<Integer>();
list.add(1);
list.add(2);
list.add(3);
list.add(4);
//法一:
for(int i=0;i<list.size();i++)
System.out.print(list.get(i));
//法二:
for(Integer item:list)
System.out.print(item);
2.ArrayList中仅能添加引用数据类型,对于基础数据类型会自动封装和解包
public static class node {
int index;
int value;
public node(int index,int value)
{
this.index=index;
this.value=value;
}
}
public static void main(String args[])
{
List<node> list = new ArrayList<>();
list.add(new node(1,2));
//错误写法:list.add({1,2})
}
3.ArrayList中set(index,object)与add(index,object)方法的区别
set是替换index位置上的值,add是包含index在内的元素都后移
List<Integer> list = new ArrayList<>();
list.add(0,0);
list.add(1,1);
for(Integer i:list)
System.out.print(i+" ");//0 1
System.out.println();
list.add(0,-1);
for(Integer i:list)
System.out.print(i+" ");//-1 0 1
System.out.println();
list.set(0,3);
for(Integer i:list)
System.out.print(i+" ");//3 0 1
4.arraylist和list的区别
A.List是接口 定义了一些方法 但是方法没有被实现;
B.ArrayList是一个类 实现了List这个接口 List里边定义的方法 在ArrayList里边都实现了
5.list 的 .subList()方法
A. .subList(fromIndex,toIndex)的范围是[fromIndex,toIndex-1],不包含toIndex
B. 一定要使用list 而不是ArrayList
List<Integer> l1=new ArrayList<Integer>();
l1.add(0);
l1.add(1);
l1.add(2);
l1.add(3);
for(Integer i:l1)
System.out.print(i);
System.out.println();
l1=l1.subList(1, 3);
for(Integer i:l1)
System.out.print(i);//1 2
ArrayList<Integer> l2=new ArrayList<Integer>();
l2.add(0);
l2.add(1);
l2.add(2);
l2.add(3);
l2=l2.subList(1, 3);//会飘红,可能需要强转
6.Collections.sort()的使用
作用就是排序容器类型,或者自定义的类
https://blog.youkuaiyun.com/qq_23179075/article/details/78753136
A.容器类型如Map、Set都是可比较的,自定义的类要是可比较的就需要实现Comparable接口,重写compareTo()方法
B.compareTo()升序是 return o1-o2,降序反之
C.若要根据其他关键字进行排序需要实现compartor接口,重写compare方法
7.Arrays.fill(arr,val);
将一个数组中的所有数字赋值为val,默认值是0
8.Arrays.copyOf(arr,length)
arr是原数组,length是需要复制的长度,返回的是数组的引用
9.实现容器数组的copy
List<Integer> l1=new ArrayList<Integer>(l);//将l中内容复制一份给l1