码迷,mamicode.com
首页 > 其他好文 > 详细

Map、Set的基本概括

时间:2019-05-28 09:41:42      阅读:122      评论:0      收藏:0      [点我收藏+]

标签:set   键值   title   插入   alt   对象属性   int   nta   相关   

Map:

在运用map和set

集合之前首先要弄清楚它们的基本定义是什么。

简介:map是一种关联式容器,但是她储存方式是以键值对(key/value)存在的。

Map用法:

定义Map集合并往集合中加入几个元素:

技术图片
    //map 键值对 json格式 根据你的键名来获取对应的值
    Map<String, Object> map=new HashMap<>();
    map.put("ht", "邵阳");
    map.put("hxc","永州");
    map.put("zsy", "岳阳");
    map.put("cpc", "株洲");
    System.out.println(map);//輸出map中添加的值
技术图片

有的时候值插入过多就会出现重复值得问题是什么样子,那要怎么解决呢?

key相同则覆盖values的值 以最后加入进去的值为真

技术图片
Map<Integer,Object> map2=new HashMap<>();
    //避免出现重复的健
    for (int i = 0; i <10; i++) {
        if (map2.containsKey(i)) {
            map2.put(i, "z"+i);
        }
    }
技术图片

如果值value相同 而key不同 又会成为什么问题?

当键值对中的值相同而健不同,你可以同时创建2个输出发现

键值对只和健有关,与值不相关。

用方法Map.entrySet(),接口Map.Entry去映射输出Map中键值(因为接口中提供getKey与getValue方法)

//用Map.Entry接口与Map.entrySet()方法映射
for (java.util.Map.Entry<Integer,Object> emp :map2.entrySet()) {
        System.out.println("key"+emp.getKey()+"values:"+emp.getValue());
    }
    System.out.println(map2);

 

Set:

简介:set也是一种关联式容器,不过它的容器底层实现原理是黑红树;

红黑树是一颗近似平衡的搜索二叉树,在对元素的查找中有很高的效率。

Set用法:

定义一个Set集合并往其中添加几条元素:

技术图片
Set<String> set=new TreeSet();
            //添加几个元素
            set.add("ht");
            set.add("zs");
            set.add("jk");
            set.add("hf");
            set.add("qq");
技术图片

set一般遵循自然排序(26个英文字母),Set集合的值是不可重复的,若是重复那么他就成了无序。

迭代器输出元素

//迭代器输出
        Iterator<String> iterator=set.iterator();
        while (iterator.hasNext()) {
            System.out.println(iterator.next());
        }

for循环遍历元素

//循环遍历输出
        for (String s : set) {
            System.out.println(s);
        }

自定义排序

技术图片
//自定义排序器
            Set<Person> set2=new TreeSet<>(new Age());
            //equals比较的是内存的地址,而不是对象属性
//            System.out.println(new Person(1,"青灯",17).equals(new Person(1,"青灯",17)));
            set2.add(new Person(1,"青灯",17));
            set2.add(new Person(1,"青灯",17));
            set2.add(new Person(1,"青灯",17));
            set2.add(new Person(1,"青灯",17));
            set2.add(new Person(1,"青灯",17));
            //foreach的底层原理就是迭代器
            for (Person p : set2) {
                //默认转换为String的类型
                System.out.println(p);
            }

Map、Set的基本概括

标签:set   键值   title   插入   alt   对象属性   int   nta   相关   

原文地址:https://www.cnblogs.com/IDIDIDIDID/p/10935086.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!