map long 做 key 引发的灾难

文章讨论了一个关于Java中使用Long作为Map键值在序列化和反序列化时遇到的问题。当使用fastjson从JSON字符串转换回Map时,由于泛型擦除,实际的key类型发生了变化,导致containsKey方法返回错误的结果。解决方法是利用TypeReference来保持类型信息。
摘要由CSDN通过智能技术生成

问题:

        Map<Long,String> 定义的map,用Long的key查询为null。

代码:

public static void main(String[] args) {
        Map<Long,String> map1 = new HashMap<>();
        map1.put(1L,"001");
        map1.put(2L,"001");
        map1.put(12345678900000L,"12345678900000L");

        String json = JSONObject.toJSONString(map1);
        Map<Long,String> map2 = JSON.parseObject(json, HashMap.class);
        Long val1 = 1L;
        boolean existLong = map2.containsKey(val1);
        System.out.println("existLong=" + existLong);
    }

打印结果: 

existLong=false

问题:

       我们想理想的结果是 true ,结果是 false,百思不得其姐。

改造代码:

public static void main(String[] args) {
        Map<Long,String> map1 = new HashMap<>();
        map1.put(1L,"001");
        map1.put(2L,"001");
        map1.put(12345678900000L,"12345678900000L");

        String json = JSONObject.toJSONString(map1);
        Map<Long,String> map2 = JSON.parseObject(json, HashMap.class);
        Long val1 = 1L;
        Integer val2 = 1;
        boolean existLong = map2.containsKey(val1);
        boolean existInt = map2.containsKey(val2);
        System.out.println("existLong=" + existLong);
        System.out.println("existInt=" + existInt);
    }

输出结果:

existLong=false
existInt=true

  脑袋瓜嗡嗡的吧,剧情完全不是我们想象的样子。

再看看:

  似乎明白了所以然,问题出现在 json转map,虽然泛型里限制了Long,而实际上map的key是fastjson默认的类型。这里泛型的知识可自行百度一下:

Map<Long,String> map2 = JSON.parseObject(json, HashMap.class);

 总结:

      Map还是尽量用String来做key,不然类型能搞死人,而且不报任何错误。

正确的用法:Map<Long,String> map2 = JSON.parseObject(json, new TypeReference<Map<Long,String>>(){});

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值