java 方法头_Java中的TeMeMAP头图方法

我正在检查treemap的headmap方法,它返回的映射部分的键严格小于tokey。所以我希望输出是b,c,但它只返回b。我做了一件奇怪的事,我改变了compareto方法,如下所示

return this.priority > o.priority ? 1 : -1;

然后它开始返回C,B,这是我所期待的。我确信这是不正确的,但我如何才能同时得到B,C,它的优先级比A低,我在哪里得到的是错误的。谢谢。

NavigableMap treeMap = new TreeMap();

PolicyTypePriorityWrapper a = new PolicyTypePriorityWrapper("A", 2);

PolicyTypePriorityWrapper b = new PolicyTypePriorityWrapper("B", 1);

PolicyTypePriorityWrapper c = new PolicyTypePriorityWrapper("C", 1);

treeMap.put(a, "A");

treeMap.put(b, "B");

treeMap.put(c, "C");

NavigableMap map = treeMap.headMap(a, false);

Set policyTypePriorityWrappers = map.keySet();

for (PolicyTypePriorityWrapper pol: policyTypePriorityWrappers) {

System.out.println(pol.getPolicyType());

}

策略类型PriorityWrapper.java

class PolicyTypePriorityWrapper implements Comparable {

private String policyType;

private int priority;

public PolicyTypePriorityWrapper(final String policyType, final int priority) {

this.policyType = policyType;

this.priority = priority;

}

public String getPolicyType() {

return this.policyType;

}

public int getPriority() {

return this.priority;

}

@Override

public boolean equals(Object o) {

if (this == o) return true;

if (o == null || getClass() != o.getClass()) return false;

PolicyTypePriorityWrapper that = (PolicyTypePriorityWrapper) o;

if (priority != that.priority) return false;

return policyType.equals(that.policyType);

}

@Override

public int hashCode() {

int result = policyType.hashCode();

result = 31 * result + priority;

return result;

}

@Override

public int compareTo(final PolicyTypePriorityWrapper o) {

return Integer.compare(this.priority, o.priority);

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值