TreeMap、TreeSet

特例说明:

       TreeMap、TreeSet两个类在加入第二个元素时,会调用Comparator比较器比较先后加入的元素是否重复(TreeMap比较的是Key值)。所以当加入第一个元素时,即使第一个元素是null,也不会报错,因为此时不会调用比较器,再次加入元素则报错。

      已测试的其他集合类HashSet / HashMap / ArrayList / LinkedList均可接受null值。


[java]  view plain  copy
  1. package com.java1029.collection;  
  2.   
  3. import java.util.ArrayList;  
  4. import java.util.HashMap;  
  5. import java.util.HashSet;  
  6. import java.util.LinkedList;  
  7. import java.util.List;  
  8. import java.util.Map;  
  9. import java.util.Set;  
  10. import java.util.TreeMap;  
  11. import java.util.TreeSet;  
  12.   
  13. public class TestNull {  
  14.       public static void main(String[] args) {  
  15.       //HashMap  允许null-null键值对  
  16.           Map<String,String> hashMap = new HashMap<String,String>();  
  17.           hashMap.put("11""ddd");  
  18.           hashMap.put("1233"null);  
  19.           hashMap.put(null"wang");  
  20.           hashMap.put(nullnull);  
  21.           System.out.println("HashMap以上代码运行成功");  
  22.            
  23.     //TreeMap  允许value值为null,不允许key值为null  
  24.          TreeMap<String,String> treeMap = new TreeMap<String,String>();  
  25.            
  26.          //Map放入第一个元素时不会调用比较器,所以不会调用比较器,不会出现NullPointerException  
  27.          //以下一行代码执行时不会报错,但当treeMapp中放入元素大于1时,就会调用比较器,出现NullPointerException  
  28.          // treeMap.put(null, null);  
  29.          treeMap.put("ddd"null);  
  30.          treeMap.put("sss"null);  
  31.          System.out.println("TreeMap以上代码运行成功");  
  32.            
  33.            
  34.     //HashSet  
  35.          Set<String> hashSet = new HashSet<String>();  
  36.          hashSet.add(null);  
  37.          hashSet.add("ddd");  
  38.          System.out.println("HashSet以上代码运行成功");  
  39.       
  40.     //TreeSet  
  41.          Set<String> treeSet = new TreeSet<String>();  
  42.          //以下两行代码执行时,会报错。理由同TreeMap  
  43.          //treeSet.add(null);  
  44.          treeSet.add("sss");  
  45.          System.out.println("TreeSet以上代码运行成功");  
  46.            
  47.     //ArrayList  
  48.          List<String> arrayList = new ArrayList<String>();  
  49.          arrayList.add(null);  
  50.          arrayList.add("dd");  
  51.          System.out.println("ArrayList以上代码运行成功");  
  52.            
  53.     //LinkedList  
  54.          List<String> linkedList = new LinkedList<String>();  
  55.          linkedList.add(null);  
  56.          linkedList.add("ddd");  
  57.          System.out.println("LinkedList以上代码运行成功");  
  58.     }  
  59. }  

  60.  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值