Map深拷贝

Map<String, String> m1 = new HashMap<String, String>();

// do sth here

Map<String, String> m2 = new HashMap<String, String>();

m2 = m1;
m2.putAll(m1);



倒数第二行只传递了一个引用,所有m1的值变化之后m2自然也跟着变了。

倒数第一行能正确的将m2生成一个新的map,即使m1变化之后也并不会影响m2的值。


Map<String, Map<String, String>> m1 = new HashMap<String, Map<String, String>>();

// do something here

Map<String, Map<String, String>> m2 = new HashMap<String, Map<String, String>>();

m2.putAll(m1);


但是,在这种还有第二层map的情况下,当更改第二层map里面的value的时候,发现两个map都一起改变了

这是因为putAll() 时第二层传递的还是引用。


    public static <K1, K2, V> Map<K1, Map<K2, V>> deepCopy(Map<K1, Map<K2, V>> original){
        Map<K1, Map<K2, V>> copy = new HashMap<K1, Map<K2, V>>();
        for(Entry<K1, Map<K2, V>> entry : original.entrySet()){
            copy.put(entry.getKey(), new HashMap<K2, V>(entry.getValue()));
        }
        return copy;
    }

m2 = deepCopy(m1);

这样得到的m2即为一个真正的新map,改变任何值两个map都不会互相影响。


原谅链接:http://stackoverflow.com/questions/11296490/assigning-hashmap-to-hashmap

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值