我遇到了这个问题,我需要PiorityBlockingQueue
对其中的项目进行排序。用户可以对添加到队列中的项目进行排序有几个选项。
我被困在的一个是试图通过Item
.
比较的选择在 的构造函数中确定MyQueue
。但是(例如,低、中、高)的计数直到以后才确定。确定后,我想调用update(String lst)
from 的方法ItemComparator
来更新,hashmap
以便排序正确。
所以我的问题是我不能调用那个方法。我知道我错过了一些东西,但我无法弄清楚。有什么帮助吗?也许有比我现在做的更好的设计?
public class ItemComparator implements Comparator<Item>
{
public void update(String lst){
test = lst;
}
public int compare(Item o1, Item o2) {
HashMap<String,Integer> priority = new HashMap<>();
priority.put("LOW", 1);
priority.put("MEDIUM", 2);
priority.put("HIGH", 3);
if (priority.get(o1.getPriority()) > priority.get(o2.getPriority())) {
return -1;
}
if (priority.get(o1.getPriority()) < priority.get(o2.getPriority())) {
return 1;
}
return 0;
}
}
此语句不适用于此类 compare.update(aString);
public class MyQueue implements AQueue{
private Comparator<Ticket> comparator;
private PriorityBlockingQueue<Ticket> listOfTickets;
private String policy;
BlockingQImpl(String processingPolicy) throws InvalidDataException {
setPolicy(processingPolicy.toUpperCase());
setComparator(policy);
}
private void setComparator(String policy) throws InvalidDataException {
if (policy.equals("THIS")) {
comparator = new ItemComparator(countString);
}
listOfTickets = new PriorityBlockingQueue<>(10, comparator);
}
public void addList(int id) {
ticks.add(id)
comparator.update(aString);
}
}