疯狂Java系列之List集合

来源:互联网 发布:ubuntu映射网络文件夹 编辑:程序博客网 时间:2024/06/05 17:13

List集合代表一个有序、可重复的集合,每个元素都有对应顺序的索引。

                                    List继承示意图

List接口新增一些方法,针对它的增加、索引、删除、替换等集合元素的方法。

代码:

 

package List;import java.util.ArrayList;import java.util.List;public class ListTest {public static void main(String[] args) {List person =new ArrayList();person.add(new String("唐三藏"));person.add(new String("孙悟空"));person.add(new String("猪八戒"));person.add(new String("沙悟净"));person.add(new String("白龙马"));System.out.println(person);person.add(1,new String("白骨精"));//将新字符串对象插入到第二个位置for(int i=0;i<person.size();i++){System.out.println(person.get(i));}//删除第三个元素person.remove(2);System.out.println(person);//返回元素第一次出现的位置,如果返回1,则在第二位System.out.println(person.indexOf(new String("沙悟净")));//返回元素最后一次出现的位置,如果返回1,则在第二位System.out.println(person.lastIndexOf(new String("沙悟净")));person.set(4, new String("红孩儿"));//将第5个元素替换成红孩儿System.out.println(person);System.out.println(person.subList(1, 3));//将第2个(包含)到第4个(不包含)截取成子集合}}

结果:

 

总结:例子很简单,基本上对照每一个结果就能知道这些底层方法的作用。


List可以存在重复对象,那么List判断对象重复的标准是什么?

List判断两个对象相等只要通过equals()方法比较返回true就可了。

 


Java8中为list还添加两个默认方法:

replaceAllUnaryOperator operator):根据指定的计算规则重新设置List集合的所有元素;

sortComparator c):根据Comparator参数对list集合的元素排序;

代码:

 

package List;import java.util.ArrayList;import java.util.List;public class Listtest2 {public static void main(String[] args) {List person=new ArrayList();person.add(new String("孙悟空"));person.add(new String("唐僧"));person.add(new String("猪八戒净坛使者"));person.add(new String("沙悟净罗汉"));person.add(new String("白龙马小白龙"));System.out.println(person);//使用目标类型为Comparator的Lambda表达式对List集合排序//根据字符串长度排序person.sort((o1,o2)->((String)o1).length()-((String)o2).length());System.out.println(person);//使用目标类型为UnaryOperator的lambda表达式来替换集合中所有元素//该Lambda表达式控制使用每个字符串的长度作为新的集合元素person.replaceAll(ele->((String)ele).length());System.out.println(person);}}

结果:


ArrayList类和vetor类

         作为List两个经典的实现类,支持List接口所有的方法。

        List是一个可以动态扩展的集合,在ArrayList或Vector中元素超出数组长度,通过initialCapacity自动增加。为提高性能,可以使用ensureCapacity(int minCapactiy)方法一次性地增加initialCapacity,这样可以减少分配的次数。

         ArrayList和Vector明显区别是:ArrayList是线程不安全的,当多个线程访问同一个ArrayList集合时,超过一个线程修改ArrayList集合,就必须手动保证该集合的安全性。vector是线程安全的。

固定长度的List

这里有个工具类Arrays,可以把一个数组或指定个数的对象转换成一个List集合,它是Arrays的内部类ArrayList的实例。

Arrays.ArrayList是一个固定长度的List集合,程序只能遍历访问该集合里的元素,不可增加、删除该集合中的元素。



原创粉丝点击