0

我有一个 cookie 管理器类,它按其域在地图中存储 cookie 列表。大多数情况下,大小将保持在 100 以下。

Map<String, CookieList> cookieMap;

每次我为连接设置 cookie 时,它​​都需要遍历所有域(String),检查它是否可以接受,然后插入CookieList. 我将多次遍历地图。我有一个单独的列表,其中包含域并进行搜索,然后CookieList通过密钥获取。

List<String> domainList;

// host is from the connection being set up
for (String domain : domainList) {
    if (host.contains(domain)) {
        CookieList list = cookieMap.get(domain);
        // set up cookies
    }
}

由于我正在使用contains,我无法直接从cookieMap. 这是一个好方法还是我应该只是迭代 Map 的 EntrySet?如果是这样,LinkedHashMap 在这个例子中会很好吗?

4

3 回答 3

3

您可以使用来获取域,而不是维护 aMap和 a 。ListMap.keySet

for (String domain : cookieMap.keySet()) {
    if (host.contains(domain)) {
        CookieList list = cookieMap.get(domain);
    }
}

这并没有什么低效的,因为 for 循环是 O(n),而对 cookieMap 的调用是 O(1)。

于 2013-03-09T18:10:23.157 回答
1
Map<String, CookieList>  coockieMap = new HashMap<String, CookieList>();
for (Map.Entry<Integer, CookieList> entry : coockieMap.entrySet()) {
    if (host.contains(entry.getKey())) {
        CookieList list = entry.getValue();
    }
}

希望这对您有所帮助。

于 2013-03-09T18:21:17.340 回答
1

我认为您的代码非常优化,如果您愿意,可以使用

domainList.retainAll(hosts)

在你的 for 循环之前,所以停止检查每个循环。有效地,您的代码将如下所示:

List<String> hostList = new ArrayList<String>(domainList); // we don't want to edit domains

hostList.retainAll(host);  

for (String hostEntry : hostList) { // I'd rename "host" so I can use it here
        CookieList list = cookieMap.get(hostEntry);
        // set up cookies
}
于 2013-03-09T19:12:50.817 回答