0

我遇到了这个问题,我需要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);
    }
}
4

1 回答 1

0

我认为您的问题是comparator.update(aString);正确的编译错误?

这是因为您已声明comparatoras Comparator<Ticket>,这意味着您将其“视为” a Comparator,而在 aComparator中,没有update()方法。

您应该将其声明为ItemComparator

IE

private ItemComparator comparator;
于 2012-10-11T04:16:02.907 回答