• 误用ArrayListMultimap引发的问题


         最近生产环境的系统在运行一段时间后,用户登录速度越来越慢,但是重启某一模块后,用户登录恢复正常。如此反复,令人提心吊胆。于是下定决心,找出问题原因。

         趁着系统运行低峰期,打印出相应Dump文件,发现Dump文件中在ArrayListMultimap对象处包含大量HashMap$Entry,由于涉及信息安全,在这里就不粘贴其对应的Dump数据了。分析存在问题的代码发现原作者引用了如下数据结构:

    Multimap<Long,Long> syncMap = ArrayListMultimap.create();
    

        但是根据原代码的业务逻辑,此处的(key,value )应当是不允许重复的。基于此分析,基本可以确定此处为对象误用:将HashMultimap误用为ArrayListMultimap.

         那么ArrayListMultimap与HashMultimap在对象去重上有啥区别呢?下面以示例来进行说明:

    一、ArrayListMultimap存储对象

    Multimap<String,String> multimap= ArrayListMultimap.create();
    multimap.put("Fruits","Banana");
    multimap.put("Fruits","Apple");
    multimap.put("Fruits","Apple");
    int size=multimap.size();
    #3
    System.out.println(size);    
    Collection<String> fruits = multimap.get("Fruits");
    #[Banana,Apple,Apple]
    System.out.println(fruits);  
    

     二、HashMultimap存储对象

    Multimap<String,String> multimap= HashMultimap.create();
    multimap.put("Fruits","Banana");
    multimap.put("Fruits","Apple");
    multimap.put("Fruits","Apple");
    int size=multimap.size();
    #2
    System.out.println(size);    
    Collection<String> fruits = multimap.get("Fruits");
    #[Banana,Apple]
    System.out.println(fruits); 
    
  • 相关阅读:
    Codeforces 631A Interview【模拟水题】
    Codeforces 651E Table Compression【并查集】
    Codeforces 651D Image Preview【二分+枚举】
    Codeforces 651C Watchmen【模拟】
    Codeforces 651B Beautiful Paintings【贪心】
    18.06.26 16年期末10:游览规划
    18.06.25 POJ4129 16年期末09:变换的迷宫
    18.06.25 POJ4150 16年期末07:上机
    18.06.25 16年期末06 42点
    18.06.25 16年期末01-05集合
  • 原文地址:https://www.cnblogs.com/moonandstar08/p/5641821.html
Copyright © 2020-2023  润新知