Collection
    -----List
               -----LinkedList    非同步
                ----ArrayList      非同步,实现了可变大小的元素数组
                ----Vector          同步
                         ------Stack
    -----Set   不允许有相同的元素
Map
    -----HashTable        同步,实现一个key--value映射的哈希表
    -----HashMap          非同步,
    -----WeakHashMap   改进的HashMap,实现了“弱引用”,如果一个key不被引用,则被GC回收
 
 

Collection


在我们编程的时候,有时候需要集中存放多个数据,可以用数组来保存多个数据,但是数组的长度是不可变的,一旦数组的长度确定了之后就无法再改变,如果要保存可变长度的数据的话,数组肯定是不行的了。而且数组也无法保存具有一定关联的数据,比如:数学–80,英语–50。为了可以保存上面的这些信息,java提供了集合类,主要是负责保存、盛装数据的。因此集合相当于一个容器类。
    集合类有两个派生类,CollectionMap,本篇文章主要讲解Collection接口


package java.util; public interface Collection<E> extends Iterable<E> {
// Query Operations
//查询的一些方法 int size();
boolean isEmpty();
boolean contains(Object o);
Iterator<E> iterator();
Object[] toArray();
<T> T[] toArray(T[] a); // Modification Operations
//修改的一些方法
boolean add(E e);
boolean remove(Object o); // Bulk Operations
//一些批量操作的方法
boolean containsAll(Collection<?> c);
boolean addAll(Collection<? extends E> c);
boolean removeAll(Collection<?> c);
boolean retainAll(Collection<?> c);
void clear(); // Comparison and hashing
//和hash对比
boolean equals(Object o);
int hashCode();

List

List的长度可变。
    List集合像一个数组,是有序的。

0 1 2 3 4 5 6
ele1 ele2 ele3 ele4 ele5 ele6 ele7

List集合的一些基本操作

List<String>    list    =    new    ArrayList<String>();
list.add("testone");
list.add(“testtwo”); //List遍历
//第一种:这种方式在循环执行过程中会进行数据锁定,性能稍差,同时,如果你想在寻欢过程中去掉某个元素,只能调用it.remove方法,不能使list.remove方法,否则一定出现并发访问的错误.
for(Iterator<String> it = ist.iterator(); it.hasNext();) {
....
} //第二种:内部调用第一种,换汤不换药,因此比Iterator慢,这种循环方式还有其他限制,不建议使用它。
for(String data:list) {
.....
} //第三种:内部不锁定,效率最高,但是当写多线程时要考虑并发操作的问题。
for(int i=0;i<list.size();i++) {
A a=list.get(i);
...
}

Set

Set集合是无序的,元元素不允许重复。

HashSet h=new HashSet();
h.add("1st");
h.add("2nd");
h.add(new Integer(3));
h.add(new Double(4.0));
h.add("2nd"); //重复元素,未被添加
h.add(new Integer(3)); //重复元素,未被添加
h.add(new Date());
System.out.println("开始:size="+h.size());
Iterator it=h.iterator();
while(it.hasNext())
{
Object o=it.next();
System.out.println(o);
} h.remove("2nd");
System.out.println("移除元素后:size="+h.size());
System.out.println(h);

Map


Map是java集合的另一个根接口,下图中是Map体系中一些常用的实现类。

map也像一个罐子,不过在map中存储的时候都是以键值对的方式存储的(key-value方式)。存储的时候,key值是不能重复的,相当于索引,而value值是可以重复的。查询value值时通过key进行查询。

package com.jackey.topic;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set; //循环遍历map的方法
public class CircleMap
{ public static void main(String[] args) { Map<String, Integer> tempMap = new HashMap<String, Integer>();
tempMap.put("a", 1);
tempMap.put("b", 2);
tempMap.put("c", 3);
// JDK1.4中 // 遍历方法一 hashmap entrySet() 遍历
System.out.println("方法一");
Iterator it = tempMap.entrySet().iterator();
while (it.hasNext()) {
Map.Entry entry = (Map.Entry) it.next();
Object key = entry.getKey();
Object value = entry.getValue();
System.out.println("key=" + key + " value=" + value);
}
System.out.println(""); // JDK1.5中,应用新特性For-Each循环
// 遍历方法二
System.out.println("方法二");
for (Map.Entry<String, Integer> entry : tempMap.entrySet()) {
String key = entry.getKey().toString();
String value = entry.getValue().toString();
System.out.println("key=" + key + " value=" + value);
}
System.out.println(""); // 遍历方法三 hashmap keySet() 遍历
System.out.println("方法三");
for (Iterator i = tempMap.keySet().iterator(); i.hasNext();) {
Object obj = i.next();
System.out.println(obj);// 循环输出key
System.out.println("key=" + obj + " value=" + tempMap.get(obj));
}
for (Iterator i = tempMap.values().iterator(); i.hasNext();) {
Object obj = i.next();
System.out.println(obj);// 循环输出value
}
System.out.println(""); // 遍历方法四 treemap keySet()遍历
System.out.println("方法四");
for (Object o : tempMap.keySet()) {
System.out.println("key=" + o + " value=" + tempMap.get(o));
}
System.out.println("11111"); // java如何遍历Map <String, ArrayList> map = new HashMap <String,
// ArrayList>();
System.out.println("java 遍历Map <String, ArrayList> map = new HashMap<String, ArrayList>();");
Map<String, ArrayList> map = new HashMap<String, ArrayList>();
Set<String> keys = map.keySet();
Iterator<String> iterator = keys.iterator();
while (iterator.hasNext()) {
String key = iterator.next();
ArrayList arrayList = map.get(key);
for (Object o : arrayList) {
System.out.println(o + "遍历过程");
}
}
System.out.println("2222");
Map<String, List> mapList = new HashMap<String, List>();
for (Map.Entry entry : mapList.entrySet()) {
String key = entry.getKey().toString();
List<String> values = (List) entry.getValue();
for (String value : values) {
System.out.println(key + " --> " + value);
}
}
}
}

最新文章

  1. Redis数据结构详解之Zset(五)
  2. 【BZOJ1688】[Usaco2005 Open]Disease Manangement 疾病管理 状压DP
  3. CentOS6.5恢复误删除的文件
  4. Hive安装
  5. django 注册、登录及第三方接口程序(4):扩展邮箱注册,登录,微博登录
  6. MySQL: 详细的sql语句
  7. Linux下dig命令使用
  8. java 中 String 类的几个问题
  9. MongoDB数据库文档操作
  10. python 学习笔记
  11. python将nan, inf转为特定的数字
  12. [信号处理技术]关于EMD的产生
  13. Metal并行计算以及Metal程序的命令行编译
  14. react 关闭eslint 配置
  15. Linux-Centos7 安装图形界面
  16. C#通过RFC连接sap系统
  17. 2019-04-09-day028-OSI七层模型
  18. Javascript加速运动与减速运动
  19. hdu 1058 dp.Humble Numbers
  20. 19个三维GIS软件对比

热门文章

  1. POJ 1664 放苹果【DFS】
  2. lftp简单使用
  3. layui中选中select标签 隐藏div
  4. BZOJ 3129 [SDOI2013]方程 (拓展Lucas)
  5. vmware vsphere出现“需要整合虚拟机磁盘”的告警处理方法(完整版)
  6. ubuntu 16.04 安装KVM-多系统
  7. Adobe AIR and Flex - 保存序列化对象文件(译)
  8. 【BZOJ 1089】[SCOI2003]严格n元树
  9. 主程的晋升攻略(4):TCP、消息分包和协议设计
  10. bzoj1010: [HNOI2008]玩具装箱toy(DP+斜率优化)