java-collection-集合的学习

这里写图片描述

package test;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Hashtable;
import java.util.IdentityHashMap;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.Stack;
import java.util.TreeMap;
import java.util.TreeSet;
import java.util.Vector;
import java.util.WeakHashMap;
import java.util.concurrent.ConcurrentHashMap;

/**
 * @description: <br/>
 * @version: 1<br/>
 * @package test.AMain.java
 * @author YangPu
 * @date 2017年7月5日 下午4:38:08
 */
public class AMain {

    public static void main(String[] args) {
        // Map map = new HashMap();
        // map.put(null, null);//
        // map.put(null, "null-value");
        // map.put("null-key", null);//
        // map.put("key", "value");//
        // map.put("key", "value1");//
        // map.put(null, "null");//
        // for (Iterator iterator = map.keySet().iterator();
        // iterator.hasNext();) {
        // Object key = iterator.next();
        // System.out.println("key:" + key + "|||value:" + map.get(key));
        // }
        // weakHashMap();
        // vector_stack();
        list();
    }

    // map集合
    public static void map() {
        // HashMap内部是无序的--多线程环境下是不安全的
        Map hashMap = new HashMap<String, String>();
        hashMap.put("hashMap", "12345");
        // LinkedHashMap继承HashMap,内部并且维护了一个链表,来存储插入时候的顺序
        Map linkedHashMap = new LinkedHashMap<String, String>();
        linkedHashMap.put("linkedHashMap", "12345");
        // 不拷贝对象--弱引用,当key被gc回收的时候,会销毁掉key-value
        Map weakHashMap = new WeakHashMap<String, String>();
        weakHashMap.put("weakHashMap", "12345");
        // 多线程环境下是安全的--Hashtable是线程安全的也是synchronized
        Map hashtable = new Hashtable<String, String>();
        // Java 5提供了ConcurrentHashMap,它是HashTable的替代,比HashTable的扩展性更好。
        Map concurrentHashMap = new ConcurrentHashMap<String, String>();
        hashtable.put("hashtable", "12345");
        // 有序的--内部原理,红黑树
        Map treeMap = new TreeMap<String, String>();
        treeMap.put("treeMap", "12345");
        // 和HashMap相比。判断相等用“==”
        Map identityHashMap = new IdentityHashMap<String, String>();
        identityHashMap.put("identityHashMap", "12345");
    }

    // map集合-WeakHashMap
    public static void weakHashMap() {
        Map weakHashMap = new WeakHashMap<String, String>();
        User user = new User("name", 12);
        weakHashMap.put(user, "12345");
        System.out.println("1");
        for (Iterator iterator = weakHashMap.keySet().iterator(); iterator.hasNext();) {
            User temp = (User) iterator.next();
            System.out.println(temp);
            System.out.println(weakHashMap.get(temp));
        }
        user = null;
        System.gc();
        System.out.println("2");
        for (Iterator iterator = weakHashMap.keySet().iterator(); iterator.hasNext();) {
            User temp = (User) iterator.next();
            System.out.println(temp);
            System.out.println(weakHashMap.get(temp));
        }
    }

    // list集合-ArrayList-LinkedList
    public static void list() {
        System.out.println("list");
        List arrayList = new ArrayList<String>();
        arrayList.add("arrayList");
        List linkedList = new LinkedList<String>();
        linkedList.add("linkedList");
    }

    // vector_stack集合
    public static void vector_stack() {
        // 与list相比,Vector是同步的,有线程安全的
        List vector = new Vector<String>();
        vector.add("vector");
        vector.add("vector");
        for (int i = 0; i < vector.size(); i++) {
            System.out.println(vector.get(i));
        }
        // Stack 类表示后进先出(LIFO)的对象堆栈
        List stack = new Stack<String>();
        stack.add("stack");
    }

    // set集合-HashSet-TreeSet-LinkedHashSet
    public static void set() {
        // 是对HashMap的一种封装--HashMap<E,Object>
        Set hashSet = new HashSet<String>();
        hashSet.add("hashSet");
        // 是对LinkedHashMap的一种封装
        Set linkedHashSet = new LinkedHashSet<String>();
        linkedHashSet.add("linkedHashSet");
        // 是对TreeMap的一种封装
        Set treeSet = new TreeSet<String>();
        treeSet.add("treeSet");
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值