Java之三大集合


①  List集合

1.1  ArrayList

ArrayList 集合: 可变数组,通过角标操作

增删改查数据

泛型的使用

迭代器的遍历

 

集合特点 :

大小不确定、可以存放多种类型、移除数据方便

public class ArrayListDemo {
    public static void main(String[] args) {
        List list = new ArrayList();

        // 增
        list.add(123);
        list.add('A');
        list.add(true);

        // 删
        list.remove(true);
        //当所删除的内容为int类型值时
        Integer i = 123;
        list.remove(i);

        // 改
        list.set(0, "BBBBB");
        System.out.println(list);

        // 查
        System.out.println(list.size());
        System.out.println(list.contains(123));
        System.out.println(list.get(0));

        //查找某个元素在集合中的位置,找不到-1
        System.out.println(list.lastIndexOf('A'));
        System.out.println("---------------------");

        // 遍历
        List list1 = new ArrayList();
        list1.add(123);
        list1.add('A');
        list1.add(true);
        list1.add("我擦..");
        System.out.println(list1);
        System.out.println("--------------");

        for (int j = 0; j < list1.size(); j++) {
            System.out.println(list1.get(j));
        }
        System.out.println("--------------");

        for (Object o : list1) {
            System.out.println(o);
        }
        System.out.println("--------------");

        // 迭代遍历
        Iterator it = list1.iterator(); while (it.hasNext()) { System.out.println(it.next()); } } } public class Demo_Array { public static void main(String[] args) { List list = new ArrayList (); list.add("数据111"); list.add("数据222"); list.add("hello"); list.add("hello"); list.add("hello"); list.add("hello"); list.add("hello"); list.add("数据444"); list.add("数据555"); list.add("hello"); list.add("hello"); list.add("hello"); System.out.println(list); // 一边遍历,一边移除 /* * for循环不行 */ for (int i = 0; i < list.size(); i++) { System.out.println(list.size()); if (list.get(i).equals("hello")) { list.remove(i); } } // 一边遍历,一边移除必须使用迭代器,而且必须使用迭代器的remove() Iterator it = list.iterator(); while (it.hasNext()) { // 记得先next,再remove String s = it.next(); // 迭代器的remove---移除当前遍历出的元素 if (s.equals("hello")) { it.remove(); } } System.out.println(list); } } public class ListTest { //ArrayList添加对象时去重 对象必须复写equals()方法 public static void main(String[] args) { List persons=new ArrayList<>(); Person xiaoming=new Person("小明", 11); for (int i = 0; i < 10; i++) { if (!persons.contains(xiaoming)) { persons.add(new Person("小明", 11)); } } System.out.println(persons.toString()); } public class Person { private String name; private int age; public Person(String name, int age) { super(); this.name = name; this.age = age; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; Person other = (Person) obj; if (age != other.age) return false; if (name == null) { if (other.name != null) return false; } else if (!name.equals(other.name)) return false; return true; } @Override public String toString() { return "Person [name=" + name + ", age=" + age + "]"; } } } 

 

1.2  Vector

/*

*

* ArrayList:速度快    安全性低

*           ArrayList动态增加数组大小为原来数组大小的1.5倍+1

*           加1是为了当数组大小为1时也能根据该流程将数组大小扩充到2

*

* Vector:   速度慢   安全性高

*          vector当增加数组大小时是默认扩展一倍

*          多一种遍历方式--枚举器

*/

 

    public static void main(String[] args) {
        Vector
                    
                    
                     
                      v = new Vector
                     
                     
                      
                      ();
        v.add("xxxx1");
        v.add("xxxx2");
        v.add("xxxx3");
        v.add("xxxx4");
        v.add("xxxx5");
        v.set(2, "qqq");
        v.remove(2);

        System.out.println(v);
        System.out.println(v.size());
        System.out.println(v.isEmpty());
        System.out.println(v.indexOf("xxxx1"));
        System.out.println(v.get(3));
        System.out.println(v.contains("xxxx51"));
        v.clear();
        System.out.println(v);

    }


    public static void main(String[] args) {

        Vector
                      
                      
                       
                        v = new Vector
                       
                       
                        
                        ();
        v.add("xxxx1");
        v.add("xxxx2");
        v.add("xxxx3");
        v.add("xxxx4");
        v.add("xxxx5");

        //遍历方式

        for (int i = 0; i < v.size(); i++) {
            System.out.println(v.get(i));
        }

        for (String s : v) {
            System.out.println(s);
        }

        Iterator
                        
                        
                          it = v.iterator(); while (it.hasNext()) { it.next(); it.remove(); } System.out.println(v); //枚举器 Enumeration 
                         
                           en = v.elements(); while (en.hasMoreElements()) { System.out.println(en.nextElement()); } } 
                          
                        
                       
                       
                      
                      
                     
                     
                    
                    

  

 

1.3  LinkedList

/*

 * LinkedList:底层结构是双向链表 

*            插入,删除很快,查找很慢

*

*ArrayList:底层结构是数组

*          插入,删除较慢,查找很快

*

*/

 

  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值