黑马软件工程师——Java基础之第14天学习笔记

黑马程序员——Java基础之第14天学习笔记

---------------------- ASP.Net+Unity开发.Net培训、期待与您交流! ----------------------

集合框架(概述):

为什么出现集合类?

面向对象语言对事物的体现都是以对象的形式体现的,为了方便对多个对象的操作,就要对对象进行存储,集合就是存储对象最常见的一种方式;

数组和集合同为容器,有何不同?

数组虽然也可以存储对象,但长度是固定的;集合长度是可变的,数组中可以存储基本数据类型,集合只能存储对象;

集合类的特点:

集合只用于存储对象,集合长度是可变的,集合可以存储不同类型的对象;

为什么会出现这么多的容器呢?

因为每一个容器对数据的存储方式都有不同,这个存储方式称之为:数据结构;

 

 

集合框架(共性方法):

1.      add方法的参数类型是Object,以便于接受任意类型对象;

2.      集合中存储的都是对象引用(地址);

 

 

集合框架(迭代器):

Iterator it = a1.iterator();//获取迭代器,用于取出集合中的元素;

while(it,hasNest())

{

       sop(it.next());

}

什么事迭代器呢?

其实就是集合取出元素的方式;

取出方式定义在集合内部,取出方式便可以直接访问集合内部的元素,即取出方式就被定义在成了内部类;

由于每一个容器的数据结构不一样,所以取出元素的动作细节也不一样,但是都有共性内容,就是判断和取出,可以将这些共性抽取,形成一个接口,Iterator;

如何获取集合的取出对象呢?

通过一个对外提供的方法,iterator();

 

 

集合框架(List集合共性方法):

List:元素是有序的,元素可以重复,因为该集合体系有索引;

Set:元素是无序的(存入喝取出的顺序不一定一致),元素不可以重复;

List:特有方法,凡是可以操作角标的方法都是该体系特有的方法;

增:add(index,element);

       addAll(index,Collection);

删:remove(index);

改:set(index,element);

查:get(index);

       subLIst(from,to);

       listIterator();

 

 

集合框架(ListIterator):

List集合特有的迭代器,ListIterator是Iterator的子接口;

在迭代时,不可以通过集合对象的方法操作集合中的元素,因为会发生ConcurrentModificationException异常;

所以,在迭代器时,只能使用迭代器的方法来操作元素,可是Iterator的方法是有限的,只能对元素进行判断,取出,删除的操作;

如果想要其他的操作,如添加,修改等,就需要使用其子接口,ListIterator;

该接口只能通过List集合的ListIterator方法获取;

 

 

集合框架(List集合具体对象的特点):

ArrayList:底层的数据结构使用的是数组结构,特点:查询速度很快,但是增删稍慢,线程不同步;

LinkedLIst:底层使用的链表数据结构,特点:增删速度很快,查询稍慢;

Vector:底层是数组数据结构,线程同步,被ArrayLIst替代了;

枚举就是Vector特有的取出方式,发现枚举和迭代器很像,其实枚举和迭代器是一样的;

因为枚举的名称和方法的名称都过长,所以被迭代器取代了,枚举慢慢的就不太常用了;

 

 

集合框架(LinkedList:

LinkedList特有方法:

addFirst();

addLast();

getFist();

getLast();

获取元素,但不删除元素,如果集合中没有元素,会出现NoSuchElementException;

removeFirst();

removeLast();

在JDK1.6出现了替代方法:

offerFirst();

offerLast():

peekFirst();

peekLast();

获取元素,但不删除元素,如果集合中没有元素,会返回null;

 

pollFirst();

pollLast();

获取元素,但是元素被删除,如果集合中没有元素,会返回null;

在迭代时循环中next调用一次,就要hasNext判断一次;

List集合判断匀速是否相同,依据是元素的equals方法;

 

 

集合框架(HashSet:

Set集合的功能和Collection是一致的;

HashSet:底层数据结构是哈希表;

              HashSet是如何保证元素唯一性的呢?

              是通过元素的两个方法,hashCode和equals来完成;

              如果元素的HashCode值相同,才会判断equals是否为true;

              如果元素的hashcode值不同,不会调用equals;

注意,对于判断元素是否存在,以及删除等操作,依赖的方法是元素的hashcode和equals方法;

---------------------- ASP.Net+Unity开发.Net培训、期待与您交流! ----------------------
1楼itmyhome前天 21:54
加油
Re: pan15055726283前天 08:34
回复itmyhomenthank you!