lucene PriorityQueue 优先队列

导读:
  PriorityQueue 实现一优先队列框架,实例非常简单,只需实现lessThan(Object a, Object b)方法即可,通过该方法可以控制大优先或小优先。
  package org.apache.lucene.search;
  /**
  * Copyright 2004 The Apache Software Foundation
  *
  * Licensed under the Apache License, Version 2.0 (the "License");
  * you may not use this file except in compliance with the License.
  * You may obtain a copy of the License at
  *
  * http://www.apache.org/licenses/LICENSE-2.0
  *
  * Unless required by applicable law or agreed to in writing, software
  * distributed under the License is distributed on an "AS IS" BASIS,
  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  * See the License for the specific language governing permissions and
  * limitations under the License.
  */
  import org.apache.lucene.util.PriorityQueue;
  final class HitQueue extends PriorityQueue {
  HitQueue(int size) {
  initialize(size);
  }
  /**
  *
  * Annotator:yezheng
  */
  protected final boolean lessThan(Object a, Object b) {
  ScoreDoc hitA = (ScoreDoc)a;
  ScoreDoc hitB = (ScoreDoc)b;
  if (hitA.score == hitB.score)
  return hitA.doc > hitB.doc; // 如果分数相同则按索引先后顺序排序
  else
  return hitA.score
  }
  }

本文转自
http://blog.lough.com.cn/post/235/
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值