集合---1
来源:互联网 发布:亚像素边缘定位 算法 编辑:程序博客网 时间:2024/05/21 13:57
集合
集合概述和分类
集合的由来:
- 我们学习的是面向对象语言,而面向对象语言对事物的描述是通过对象体现的,为了方便对多个对象进行操作,我们就必须把这多个对象进行存储。
- 而要想存储多个对象,就不能是一个基本的变量,而应该是一个容器类型的变量,在我们目前所学过的知识里面,有哪些是容器类型的呢?
- 数组和StringBuffer。但是呢?StringBuffer的结果是一个字符串,不一定满足我们的要求,所以我们只能选择数组,这就是对象数组。
- 而对象数组又不能适应变化的需求,因为数组的长度是固定的,这个时候,为了适应变化的需求,Java就提供了集合类供我们使用。 *
数组和集合的区别?
A:长度区别 数组的长度固定 集合长度可变 B:内容不同 数组存储的是同一种类型的元素 而集合可以存储不同类型的元素 C:元素的数据类型问题 数组可以存储基本数据类型,也可以存储引用数据类型 集合只能存储引用类型
刚说过集合是存储多个元素的,但是呢,存储多个元素我们也是有不同需求的:
比如说,我要这多个元素中不能有相同的元素,再比如说,我要这多个元素按照某种规则排序一下。针对不同的需求,Java就提供了不同的集合类,这样呢,Java就提供了很多个集合类。
这多个集合类的数据结构不同,结构不同不重要的,重要的是你要能够存储东西,并且还要能够使用这些东西,比如说判断,获取等。既然这样,那么,这多个集合类是有共性的内容的,我们把这些集合类的共性内容不断的向上提取,最终就能形成集合的继承体系结构。
数据结构:数据的存储方式。
collection
Collection:
是集合的顶层接口,它的子体系有重复的,有唯一的,有有序的,有无序的。
Collection的功能概述:
1:添加功能 boolean add(Object obj):添加一个元素 boolean addAll(Collection c):添加一个集合的元素2:删除功能 void clear():移除所有元素 boolean remove(Object o):移除一个元素 boolean removeAll(Collection c):移除一个集合的元素(是一个还是所有)3:判断功能 boolean contains(Object o):判断集合中是否包含指定的元素 boolean containsAll(Collection c):判断集合中是否包含指定的集合元素(是一个还是所有) boolean isEmpty():判断集合是否为空4:获取功能 Iterator<E> iterator()(重点)5:长度功能 int size():元素的个数 面试题:数组有没有length()方法呢?字符串有没有length()方法呢?集合有没有length()方法呢?6:交集功能 boolean retainAll(Collection c):两个集合都有的元素?思考元素去哪了, 返回的boolean又是什么意思呢?7:把集合转换为数组 Object[] toArray()
Iterator iterator():迭代器,集合的专用遍历方式
Object next():获取元素,并移动到下一个位置。
NoSuchElementException:没有这样的元素,因为你已经找到最后了。
- boolean hasNext():如果仍有元素可以迭代,则返回 true。
List
List集合的特点:
有序(存储和取出的元素一致),可重复的。
List集合的特有功能:
A:添加功能 void add(int index,Object element):在指定位置添加元素 B:获取功能 Object get(int index):获取指定位置的元素 C:列表迭代器 ListIterator listIterator():List集合特有的迭代器 D:删除功能 Object remove(int index):根据索引删除元素,返回被删除的元素 E:修改功能 Object set(int index,Object element):根据索引修改元素,返回被修饰的元素
List的子类特点:
ArrayList: 底层数据结构是数组,查询快,增删慢 线程不安全,效率高 Vector: 底层数据结构是数组,查询快,增删慢 线程安全,效率低 LinkedList: 底层数据结构是链表,查询慢,增删快 线程不安全,效率高
* Vector的特有功能:
1:添加功能 public void addElement(Object obj) -- add() 2:获取功能 public Object elementAt(int index) -- get() public Enumeration elements() -- Iterator iterator() boolean hasMoreElements() hasNext() Object nextElement() next()
LinkedList的特有功能:
A:添加功能 public void addFirst(Object e) public void addLast(Object e) B:获取功能 public Object getFirst() public Obejct getLast() C:删除功能 public Object removeFirst() public Object removeLast()
set
Set接口概述
一个不包含重复元素的 collection。
HashSet类概述
- 不保证 set 的迭代顺序
- 特别是它不保证该顺序恒久不变。
- HashSet如何保证元素唯一性
- 底层数据结构是哈希表(元素是链表的数组)
- 哈希表依赖于哈希值存储
- 添加功能底层依赖两个方法:
- int hashCode()
- boolean equals(Object obj)
LinkedHashSet:底层数据结构由哈希表和链表组成。
哈希表保证元素的唯一性。 链表保证元素有序。(存储和取出是一致)
TreeSet:能够对元素按照某种规则进行排序。
排序有两种方式 A:自然排序 B:比较器排序
0 0
- 集合1
- 集合 - 1
- 集合1
- 集合1
- 集合1
- 集合---1
- 集合1
- 集合-1
- 集合1
- 集合1
- 集合和泛型2-----集合1
- 黑马程序员-集合1-List集合
- 集合1——Collection集合
- 集合1--List集合及泛型
- Hibernate映射集合属性1__Set集合
- java集合框架(1、集合介绍)
- 集合框架专题1-集合框架概述
- 集合框架1,数组集合ArrayList
- comparator接口与Comparable接口的区别
- servlet (1) 基础
- HDOJ 1034 Candy Sharing Game(模拟)
- 【项目基础】SSO理论篇
- 实现带参数的L脚本
- 集合---1
- poj1273 Drainage Ditches
- Android - Buttons
- android错误 之eglChooseConfig failed EGL_NOT_INITIALIZED
- 利用switch解决问题 课后题目
- 完全二叉树的深度优先搜素
- @autowired详解
- equal() 和 == 的区别
- Java基础——Java重点基础之集合框架(四)