栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

集合练习题02

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

集合练习题02

Exercise03
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
​
public class Exercise03 {
    public static void main(String[] args) {
        
​
        Map m = new HashMap();
        //存入数据:Jack - 650 ; Tom - 1200 ; Rose - 2900;
        m.put("Jack",650);
        m.put("Tom",1200);
        m.put("Rose",2900);
        System.out.println(m);
​
        //2.将Jack的工资更改为2600;
        m.put("Jack",2600);
        System.out.println(m);
​
        //3.为所有员工加工资100;
        Set set = m.keySet();
        for (Object o : set) {
            m.put(o,(Integer)m.get(o)+100);
        }
        System.out.println(m);
​
        //4.遍历集合中所有的员工;
        Set set1 = m.entrySet();
        for (Object o : set1) {
            Map.Entry entry = (Map.Entry)o;
            System.out.println(entry.getKey() + " - " + entry.getValue());
        }
​
        //5.遍历集合中所有的工资。
        Collection values = m.values();
        for (Object o : values) {
            System.out.println(o);
        }
​
    }
}
Exercise04

分析HashSet和TreeSet愤怒别如何实现去重的:

(1)HashSet的去重机制:hashCode() + equals(),底层先通过存入对象,进行运算得到一个hash值,通过hash值得到对应的索引,如果发现table索引所在的位置,没有数据,就直接加入,如果有数据,就进行equals比较[遍历比较],如果比较后,不相同,就加入,否则就不加入

(2)TreeSet的去重机制:如果你传入了一个Comparator匿名对象,就使用实现的compare去重,如果方法返回0,就认为是相同的元素/数据,就不添加,如果你没有传入一个Comparator匿名对象,则以你添加的对象实现的Compareable接口的compareTo去重。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/716773.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号