当前位置:  开发笔记 > 编程语言 > 正文

如何比较地图与列表

如何解决《如何比较地图与列表》经验,为你挑选了1个好方法。

抱歉标题,我找不到更好的一个,我知道这听起来令人困惑.问题如下:

我有一个HashMap,如下所示:

Map myMap;

另外,我有一个看起来如下的列表:

List myList;

ClassB如下所示:

   public class ClassB{

    //many things

    private String someString;
    //getter
    //setter
    }
}

someString是键字符串 myMap

我想从地图中删除所有在myList迭代次数最少的列表中找不到的对象,因为这种清理将始终每隔几秒发生一次.

任何算法?模式甚至例子?

谢谢



1> alfasin..:

你必须List myList至少迭代一次才能这样做,但是你可以完全用一次迭代来完成它,这使它成为理想的算法.

创建一个新的Map,并为列表中的每个元素检查它myMap是否存在以及是否存在 - 将其添加到您创建的新Map中.完成迭代后,只需指定:myMap = newMap;然后就完成了.

注意:这是理想的步数最少,但它使用更多的内存比一个"就地"算法.


@MarwanJaber你应该检查两个选项,并避免任何"优化",除非需要.请记住,通过"复制"地图,您实际上只复制指向对象的指针,而不是*对象本身,因此除非您有*很多*对象,否则不需要"优化"!
推荐阅读
coco2冰冰
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有