黑马程序员-集合1-List集合

来源:互联网 发布:织梦cms视频模板 编辑:程序博客网 时间:2024/05/01 12:07

集合1-List集合

集合框架 Collection

在java.util包中

Collection

|--List(列表):元素是有序的,元素可以重复。因为该集合体系有索引。

|--ArrayList:底层的数据结构使用的是数组结构。特点:查询速度很快。但是增删稍慢。线程不同步。可变数组长度延长50%

|--LinkedList:底层使用的链表数据结构。特点:增删速度很快,查询稍慢。线程不同步。

|--Vector:底层是数组数据结构。线程同步。被ArrayList替代了。因为效率低。可变数组长度100%延长,

一般开发中在要求线程同步的时候对ArrayList加锁也不使用Vector。

|--Set(集):元素是无序,元素不可以重复。

问什么会出现那么多的集合容器呢。

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

集合类

1.为什么出现集合类?

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

2.数组和集合类同是容器,有何不同?

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

3.集合类的特点:

1.集合只用于存储对象,

2.集合长度是可变的,

3.集合可以存储不同类型的对象。

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

Collection定义了集合框架的共性功能。

1,添加

add(e);,add方法的参数类型是Object。以便于接收任意类型对象。

addAll(collection); //在集合中添加一个集合中的元素。

2,删除

remove(e);删除一个 任意类型的元素,返回boolean类型的值。

removeAll(collection); 移除此 collection 中那些也包含在指定 collection 中的所有元素

clear(); 移除此 collection 中的所有元素,即清空集合。

3,判断。

contains(e);如果此 collection 包含指定的元素,则返回 true。

isEmpty(); 判断集合是否为空,空则返回true

4,获取

iterator(); 获取一个迭代器对象。

size(); 获取集合的长度。

5,获取交集。

retainAll();仅保留此 collection 中那些也包含在指定 collection 的元素

6.获取并集。

removeAll();移除此 collection 中那些也包含在指定 collection 中的所有元素

7,集合变数组。

Object[] toArray();返回包含此 collection 中所有元素的数组

<T> T[] toArray(T[] a) 返回包含此 collection 中所有元素的数组;返回数组的运行时类型与指定数组的运行时类型相同。

什么是迭代器呢?

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

迭代器是取出方式,会直接访问集合中的元素。

所以将迭代器通过内部类的形式来进行描述。

通过容器的iterator()方法获取该内部类的对象。

迭代器设计方式:

对于集合中元素的取出,不只一共动作,用一个函数不足以来描述,所以将取出的方式封装到一个对象中,并且,因为数据结构不同,每一个数据的取出方式也都不一样。。所以,取出方式需要被描述一下,就定义了一个类进行描述,因为取出方式是集合提供的,所以描述取出方式的类定义在集合内部,这样取出方式就可以直接访问集合内部的元素。那么取出方式就定义为了内部类,而每一个容器的数据结构不一样,所以抽取的动作细节也不一样,但是都有共性的内容,判断和取出,那么,将这些共性内容进行抽取,封装到内部类中。

下面是collection接口中的方法示例:

Java代码 复制代码 收藏代码
  1. class CollectionDemo
  2. {
  3. public static void main(String[] args)
  4. {
  5. base_method();
  6. }
  7. public static void base_method()
  8. {
  9. //创建一个集合容器。使用Collection接口的子类。ArrayList
  10. ArrayList al = new ArrayList();
  11. //1,添加元素。
  12. al.add("java01");//add(Object obj);
  13. al.add("java02");
  14. al.add("java03");
  15. al.add("java04");
  16. ArrayList al2 = new ArrayList();
  17. al2.add("java03");
  18. al2.add("java04");
  19. al2.add("java05");
  20. al2.add("java06");
  21. //打印原集合。
  22. sop("原集合:"+al);
  23. //3,删除元素。
  24. //al.remove("java02");
  25. //al.clear();//清空集合。
  26. //4,判断元素。
  27. sop("java03是否存在:"+al.contains("java03"));
  28. sop("集合是否为空?"+al.isEmpty());
  29. //2,获取个数。集合长度。
  30. sop("size:"+al.size());
  31. //打印改变后的集合。
  32. sop(al);
  33. //al.retainAll(al2);//获取al和al2的交集存入到al中,al1中只会保留和al2中相同的元素。
  34. //al.removeAll(al2);//删除al中与al2相同部分的元素,即取并集。
  35. sop("al1:"+al);
  36. sop("al2:"+al2);
  37. //对集合中的元素进行遍历。
  38. for(Iterator it = al.iterator(); it.hasNext() ; )
  39. {
  40. sop(it.next());
  41. }
  42. }
  43. public static void sop(Object obj)
  44. {
  45. System.out.println(obj);
  46. }
  47. }

原创粉丝点击