java集合框架详解
1.java集合框架概述
java se包含了由一组类和接口组成的java集合框架(java collection framework,简称jcf),其主要功能是用来将存储的数据以某种结构组织,并以特定的方式来访问这些数据,其目标是提供一个处理对象集合的通用框架,减少程序员处理不同对象集合时的编码量。
集合类中的一些区别,除了它们是否支持重复元素操作外,还包括元素是否有顺序,以及是否允许添加null元素。java集合框架中根据这三个区别,将对象的存储方式分为三种类型,分别是:
- set(集):对象容器中的对象没有顺序,且不能重复。
- list(列表):对象容器中的对象按照索引顺序排序,而且可以有重复的对象。
- map(映射):对象容器中的元素包含一对“键对象-值对象”映射,其中键对象不能重复,值对象可以重复。
为支持对象的排序和遍历访问操作,java集合框架中又提供了几个接口:
- 接口sortedset为set类型容器提供拍戏功能。
- 接口sortedmap为map类型容器提供对键对象的排序。
- 接口comparable和comparator用来实现集合中对象的排序。
2.collection接口和iterator接口
collection接口中定义了collection对象共有的一些基本方法
方法 | 描述 |
int size() | 返回当前集合中包含的元素个数 |
isempyt() | 判断集合中是否含有元素 |
boolean contains(objact o) | 判断集合中是否含有某一指定元素 |
add(objact o) | 向集合中添加某一个元素 |
remove(objact o) | 从集合中删除某一元素 |
iterator iterator() | 返回一个遍历器,用来访问集合中的各个元素 |
iterator接口是一种用于遍历集合的接口。
方法 | 描述 |
hasnext() | 如果集合中还有更多元素,该方法返回true |
next() | 返回集合中的下一个元素 |
remove() | 删除iterator返回的最后一个元素 |
1.list接口
list接口继承自collection接口,它有如下特点:
- list中的元素是有顺序的。
- list通常允许重复元素。
- list的实现类通常支持null元素。
- 可以通过索引访问list对象容器中的元素。
list接口最常用的实现类是arraylist类和linkedlist类。
1).arraylist
程序实例:
package lei; import java.util.arraylist; import java.util.list; public class test { public static void main(string[] args) { list list = new arraylist<>(); list.add(1); list.add("zhangsan"); list.add(false); list.add('a'); list.add(0, "lisi"); list.add(1); list.remove(1); list.remove(2); list.set(0, "wangwu"); for (int i = 0; i < list.size(); i++) { system.out.println(list.get(i)); } } }
object类定义的equals()方法只有在传递给该方法的对象与调用该方法的对象是同一对象的时候,才会返回true。可以通过重写equals()方法来把具有相同状态的两个对象被看做是同一对象。
2).linkedlist
方法 | 描述 |
void addfirst | 在链表开头添加一个对象 |
void addlast | 在链表末尾添加一个对象 |
getfirst() | 返回链表中的第一个元素 |
getlast() | 返回链表中的最后一个元素 |
removefirst() | 删除链表中的第一个元素 |
removelast() | 删除链表中的最后一个元素 |
程序实例:
package lei; import java.util.linkedlist; import java.util.list; public class test2 { public static void main(string[] args) { linkedlist l=new linkedlist<>(); l.add("zhangsan"); l.add("lisi"); l.addfirst(1); l.addlast(4); system.out.println(l.getfirst()); system.out.println(l.getlast()); l.removefirst(); l.removelast(); for (int i = 0; i < l.size(); i++) { system.out.println(l.get(i)); } } }
linkedlist与arraylist的选择
如果列表需要快速存取,但不经常进行元素的插入和删除操作,那么选择arraylist会好一些;如果需要对;列表进行频繁的插入和删除操作,那么就应该选择linkedlist。
2.set接口
set接口继承自collectiion接口,同时也继承了collection接口的全部方法。set接口有以下特点:
- set类型容器中不能包含重复元素。当加入一个元素到容器中时,要比较元素的内容是否存在重复的,所以加入set类型对象容器的对象必须重写equals()方法。
- 元素能能有顺序,也可能没有顺序。
- 因为元素可能没有顺序,所以不能基于下标访问set中费元素。
实现set接口最常用的是hashset类和treeset类。
1).hashset
hashset类是基于哈希算法的set接口实现,它主要有如下几个特点:
- 当遍历hashset时,其中的元素是没有顺序的。
- hashset中不允许出现重复元素。这里的重复元素是指有相同的哈希码,并且用equals()方法进行比较时,返回true的两个对象。
- 允许包含null元素。
如果我们编写的类重新定义了equals方法,那么这个类也必须重新定义hashcode()方法,并且保证当两个对象用equals方法比较结果为true时,这两个对象的hashcode()方法的返回值相等。
程序实例:
package lei; import java.util.hashset; import java.util.set; public class test4 { public static void main(string[] args) { set<string> set=new hashset<string>(); set.add("zhangsan"); set.add("lisi"); for(string s:set){ system.out.println(s); } } }
2).treeset
treeset类不仅实现类set接口,还实现了sortedset接口,从而保证集合中的对象按照一定的顺序排序。当向treeset集合中添加一个对象时,会把它插入到有序的对象序列中,但是这种排序并不是按照对象添加的顺序排序,而是按照一定的算法来排序。
treeset使用元素的自然顺序对元素进行排序,或者根据创建set时提供的comparator进行排序。treeset支持自然排序和自定义排序两种排序方式。
3.map接口
map(映射)接口是java集合框架中不同于collection接口的另一个重要接口,它对应的是在一种从键(key)到值(value)的对应关系的集合。map类型的对象容器里面保存着两组对象,一组对象用于保存map里的key,另外一组用于保存value。key和value可以升级任何引用类型的数据。key不能重复,但是value可以重复。
1).hashmap
hashmap是基于哈希算法的map接口的实现。hashmap将它的键保存在哈希表中进行维护,键是唯一的。但是,hashmap并不保证键以特定顺序排列,特别是不保证顺序永久不变。
hashmap类实现了map接口,从而具有map接口的所有方法。
package day1228; import java.util.*; public class hashmapdemo { public static void main(string[] args) { // 创建一个新的hashmap map<string, string> map = new hashmap<string, string>(); map.put("a1", "xiao"); map.put("b2", "xiaol"); map.put("a4", "xiaosd"); map.put("b1", "12a"); map.put("a3", "1"); // 使用iterator遍历 键和值 system.out.println("之前的map值是:"); set<string> keys = map.keyset(); for (iterator<string> i = keys.iterator(); i.hasnext();) { string key = i.next(); string value = map.get(key); system.out.println(key + "=" + value); } // 删除键为"a4"的值 system.out.println("\n删除键值为a4的元素"); map.remove("a4"); // //使用iterator遍历 键和值 system.out.println("\n之后的map值:"); keys = map.keyset(); for (iterator<string> i = keys.iterator(); i.hasnext();) { string key = i.next(); string value = map.get(key); system.out.println(key + "=" + value); } } }
2).treemap
treemap类是基于红黑树算法的map接口实现。treemap中键的存放方式与treeset相似,它将键存放在树中,键的顺序按照自然顺序或者自定义顺序两种方式排列。
程序实例:
package day1228; import java.util.*; public class treemapdemo { public static void main(string[] args) { //创建一个新的treemap map<integer, string> map = new treemap<integer, string>(); map.put(1, "one"); map.put(2, "two"); map.put(3, "three"); map.put(4, "four"); map.put(5, "five"); //使用iterator显示键和值 system.out.println("之前的map值为:"); set<integer> keys=map.keyset(); for(object key:keys){ string value=map.get(key); system.out.println(key+"="+value); } //删除键为3的值 system.out.println("\n删除键值为3的元素"); map.remove(3); //使用iterator显示键和值 system.out.println("\n之后的值map为:"); for(object key:keys){ string value=map.get(key); system.out.println(key+"="+value); } } }
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!