Java 就提供了特设类,比如:Dictionary, Vector, Stack, 和 Properties 这些类用来存储和操作对象组。虽然这些类都非常有用,但是它们缺少一个核心的,统一的主题。
集合框架被设计成要满足以下几个目标:
1.该框架必须是高性能的。
2.基本集合(动态数组,链表,树,哈希表)的实现也必须是高效的。
3.该框架允许不同类型的集合,以类似的方式工作,具有高度的互操作性。
4.对一个集合的扩展和适应必须是简单的。
所以有了集合框架,其都包含如下内容:
- 接口:是代表集合的抽象数据类型。例如 Collection、List、Set、Map 等(只能装入包装类型,不能装入基本类型)。之所以定义多个接口,是为了以不同的方式操作集合对象
- 实现(类):是集合接口的具体实现。从本质上讲,它们是可重复使用的数据结构,例如:ArrayList、LinkedList、HashSet、HashMap。
- 算法:是实现集合接口的对象里的方法执行的一些有用的计算,例如:搜索和排序。这些算法被称为多态,那是因为相同的方法可以在相似的接口上有着不同的实现。参考
比如使用Map抽象类和其具体实现HashMap,以及List和其具体实现ArrayList
import java.io.*;
import java.util.*;
class test
{
public static void main (String[] args) throws java.lang.Exception
{
Map<String,String> mp=new HashMap<String,String>();
List<String> l=new ArrayList<String>();
l.add("ajhsfdb");
System.out.println(l.get(0));
mp.put("a","shdiasd");
System.out.println(mp.get("a"));
System.out.println(mp);
System.out.println(l);
Vector x=new Vector();
x.add("shid0");
x.add("auyd");
System.out.println(x);
}
}
输出:
ajhsfdb
shdiasd
{a=shdiasd}
[ajhsfdb]
[shid0, auyd]
同Vectory一样要使用get方法来获取对应索引或键所对应的元素。同时也可以直接打印所有元素出来。
遍历
1.第一种就是使用get来获取
2.第二种类似for-each
import java.io.*;
import java.util.*;
class test
{
public static void main (String[] args) throws java.lang.Exception
{
Map<String,String> mp=new HashMap<String,String>();
mp.put("1:","String1");
mp.put("2:","String2");
mp.put("3:","String3");
System.out.println(mp);
for(Map.Entry<String,String> entry:mp.entrySet()){
System.out.println(entry.getKey()+entry.getValue());
}
List<Integer> l=new ArrayList<Integer>();
l.add(1);
l.add(2);
for(Integer en:l){
System.out.println(en);
}
}
}
输出:
{3:=String3, 2:=String2, 1:=String1}
3:String3
2:String2
1:String1
1
2
本文深入探讨了Java集合框架的设计理念,包括其高性能、高效实现、互操作性和易于扩展的目标。详细介绍了集合框架中的主要组件,如接口(Collection、List、Set、Map)、实现类(ArrayList、LinkedList、HashSet、HashMap)和算法,以及如何使用Map和List的具体实现。
1252

被折叠的 条评论
为什么被折叠?



