黑马程序员_集合体系(一)

本文详细介绍了Java集合体系的基础概念、特点及其与数组的区别,并深入探讨了集合的主要功能,包括添加、删除、判断、遍历等操作。此外还解析了Iterator迭代器原理及List特有功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

------<a href="http://www.itheima.com" target="blank">Java培训、Android培训、iOS培训、.Net培训</a>、期待与您交流! -------

一,集合体系

1.概念:java是一种面向对象语言,如果我们要针对多个对象进行操作,就必须对多个对象进行存储。
        而对多个元素进行存储,前面我们学习过数组,数组的弊端,长度固定。这样,数组将不能
        满足变化的要求。所以,java就提供了集合供我们使用。简单的说集合就是一个存储对象的可容器.

        2.特点:

                (1)长度可以发生改变
(2)只能存储对象
(3)可以存储多种类型对象(一般存储的还是同一种)

      数组与集合的区别:

            集合:1、长度可变
               2、只能存储引用数据类型
               3、一个集合当中可以存储多种数据类型
    数组:
               1、长度固定.
               2、既可以存储基本数据类型,也可以存储引用数据类型.
               3、只能存储同一类型的数据.

   集合体系的学习方法: 学习顶层,用底层.

        单例集合体系图  (顶层)Collection--List      --ArrayList:底层是数组结构,查询块,增删慢,不安全
                --Vector:底层是数组结构,查询快,增删慢,安全.
                                        --LinkedList:底层是链式结构.增删块,查询慢.不安全


                                  --Set       --HashSet:底层是哈希表结构.不安全
                                         --TreeSet:底层是二叉数结构,不安全


三.集合的功能

    A:添加元素


          boolean add( Object obj )  
            向集合中添加元素
          boolean addAll( Collection c )  (了解即可非重点)
           向集合中添加集合
   B:删除元素。

         void clear()  
         删除集合中所有元素
         boolean remove( Object obj) 
         删除集合中指定的元素
         boolean removeAll( Collection c )
          在集合中删除一个指定集合中的元素


   C:判断功能。
     boolean isEmpty()
      判断集合是否为空
     boolean contains( Object o )
     判断集合中是否包含指定元素
     boolean containsAll( Collection c ) 
     判断大集合中是否包含小集合  c是小集合
   D:遍历功能。
    Iterator iterator() 
    用集合对象获取迭代器对象
   E:长度功能。
     int size()
     获取集合的长度
   F:交集功能
     boolean retainAll( Collection c ) (了解即可非重点)
     判断两个集合中的数据是否存在交集

.Iterator迭代器的原理

                      由于多种集合的数据结构不同,所以存储方式不同,所以,取出方式也不同。
      这个时候,我们就把判断和获取功能定义在了一个接口中,将来,遍历哪种
     集合的时候,只要该集合内部实现这个接口即可。
   迭代器源码
public interface Iterator
{
public abstract boolean hasNext();
public abstract Object next();
}


public interface Collection
{
public abstract Iterator iterator();
}


public interface List extends Collection
{
...
}

public class ArrayList implements List
{
public Iterator iterator()
{
return new Itr();
}


private class Itr implements Iterator
{
public boolean hasNext(){...}
public Object next(){...}
}
}

四.List的特有功能

        (1)List的特有功能(自己补齐)
1、添加功能
void add(int index,Object obj): 
2、删除功能
Object remove(int index): 
3、修改功能
Object set(int index,Object obj): 
4、获取功能
Object get(int index): 
int indexOf(Object obj): 
ListIterator listIterator():
(2)List的遍历方式
1、Iterator迭代器
2、ListIterator迭代器(了解)
3、普通for+get()
(3)ListIterator迭代器
是Iterator的子接口。

          并发修改异常怎么产生的?
             产生原因:在用迭代器遍历集合过程中,对集合进行了修改,这个时候集合改变了
                             但是依赖于集合的迭代器并没有改变,这个时候就会出现并发修改异常。

           解决办法:1.第一种方法全部用集合进行操作(遍历集合的时候用for循环去做)元素是添加的最后的.

                           2.第二种方式全部使用迭代器去做。(要用List集合当中特有的迭代器ListIterator)元素是添加到刚                                遍历的那个元素后面

五.list的子类ArrayList

    (1)存储自定义对象去重复 
       1、用ArrayList储存自定义元素的时候想要去除重复元素怎么办?
         要在对象所属类中重写equals()方法
     重写的标准代码:
        public boolean equals(Object obj) {
// 提高效率
if (this == obj) {
return true;
}


// 提高健壮性
if (!(obj instanceof Student)) {obj 是不是属于 Student
return false;
}


// 向下转换
Student s = (Student) obj;
return this.name.equals(s.name) && this.age == s.age;
}

六.Vector的特有功能
        添加功能
void addElement(Object obj)---add()
获取功能
public Object elementAt(int index)---get()
public Enumeration elements()----Iterator
boolean hasMoreElements()---hasNext()
Object nextElement()-----next()
长度功能
int size()
JDK升级从安全,效率,简化书写三方面考虑

七.LinkedList的特有功能
     A:添加功能
        void addFirst( Object o ) 在第一个位置添加元素
         void addLast( Object o )在最后一个位置添加元素
     B:获取功能
         Object getFirst()获取第一个位置的元素
          Object getLast()获取最后一个位置的元素
     C:删除功能
         Object removeFirst()删除第一个位置的元素
        Object removeLast()删除最后一个位置的元素

      泛型的概述和简单使用
         概念:任意的类型,是一种把明确数据类型的工作放在了
                    创建对象或调用方法时候进行的特殊的类型.
         格式:<数据类型>
       泛型的好处
                 A:解决黄色警告线问题
                 B:把运行期间的类型转换异常,提前到了编译期
                C:优化程序设计
                如果类或接口有<?> 那么就是泛型的体现, 泛型就在集合中用,其他地方不用

       增强for的概述和使用
       格式for( 数组或Collection集合中元素类型  变量名  :数组或Collection集合对象 )
              {
                         使用变量名即可
               }

       作用:简化数组和Collection 集合的变量
            增强for是来替换迭代器.增强for的本质就是迭代器
            ArrayList遍历有几种方式.5种,转数组,普通迭代器,列表迭代器.普通for.增强for


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值