我正在为我的搜索引擎构建一个倒排索引文件。我已经编写了这个类,但是当我尝试测试它时,程序卡在这部分:
for (final HashObject value: list) {
if(url.equals(value.getUrl()))
value.setFrequency();
if(!url.equals(value.getUrl())){
list.add(new HashObject(title, term, url, 1, 1));
}
}
每当我删除上面放置的代码块时,整个搜索引擎都会继续正确爬行。由于程序没有采取进一步的行动,它似乎被卡住了......你可以在这里看到整个代码:
/*
* Classname: InvertedFile
* Version: 1.1
* Date: 15/04/2014
* Copyright by Mateusz Michalski
* Description: This class implements an inverted builder for storing results of crawling.
*/
package searchengine;
import java.util.*;
import java.util.concurrent.ConcurrentHashMap;
public class InvertedFile
{
ConcurrentHashMap<String, List<HashObject>> myMap = new ConcurrentHashMap<>();
public static int docCollection = 0;
SearchEngine searchEngine = new SearchEngine();
public void insertValues(String title, String term, String url)
{
if (!myMap.containsKey(term)){
List<HashObject> list = new ArrayList<>();
list.add(new HashObject(title, term, url, 1, 1));
myMap.put(term, list);
}
if(myMap.containsKey(term)){
List<HashObject> list = myMap.get(term);
for (final HashObject value: list) {
if(url.equals(value.getUrl()))
value.setFrequency();
if(!url.equals(value.getUrl())){
list.add(new HashObject(title, term, url, 1, 1));
//for (HashObject val: itemList)
//val.setDoc();
}
}
myMap.put(term, list);
}
}
}
我不知道为什么它会卡在那个 for 循环中。我可能已经太累了,希望没有看到小错误......有人可以给我他们对这段代码的意见吗?