当前位置: 首页>>代码示例>>Java>>正文


Java Bits.MatchAllBits方法代码示例

本文整理汇总了Java中org.apache.lucene.util.Bits.MatchAllBits方法的典型用法代码示例。如果您正苦于以下问题:Java Bits.MatchAllBits方法的具体用法?Java Bits.MatchAllBits怎么用?Java Bits.MatchAllBits使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.apache.lucene.util.Bits的用法示例。


在下文中一共展示了Bits.MatchAllBits方法的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: getMissingBits

import org.apache.lucene.util.Bits; //导入方法依赖的package包/类
private Bits getMissingBits(final long offset) throws IOException {
  if (offset == -1) {
    return new Bits.MatchAllBits(maxDoc);
  } else {
    final IndexInput in = data.clone();
    return new Bits() {

      @Override
      public boolean get(int index) {
        try {
          in.seek(offset + (index >> 3));
          return (in.readByte() & (1 << (index & 7))) != 0;
        } catch (IOException e) {
          throw new RuntimeException(e);
        }
      }

      @Override
      public int length() {
        return maxDoc;
      }
    };
  }
}
 
开发者ID:lamsfoundation,项目名称:lams,代码行数:25,代码来源:Lucene45DocValuesProducer.java

示例2: getMissingBits

import org.apache.lucene.util.Bits; //导入方法依赖的package包/类
private Bits getMissingBits(final long offset) throws IOException {
  if (offset == -1) {
    return new Bits.MatchAllBits(maxDoc);
  } else {
    int length = (int) ((maxDoc + 7L) >>> 3);
    final RandomAccessInput in = data.randomAccessSlice(offset, length);
    return new Bits() {
      @Override
      public boolean get(int index) {
        try {
          return (in.readByte(index >> 3) & (1 << (index & 7))) != 0;
        } catch (IOException e) {
          throw new RuntimeException(e);
        }
      }

      @Override
      public int length() {
        return maxDoc;
      }
    };
  }
}
 
开发者ID:lamsfoundation,项目名称:lams,代码行数:24,代码来源:Lucene49DocValuesProducer.java

示例3: getDocsWithField

import org.apache.lucene.util.Bits; //导入方法依赖的package包/类
@Override
public Bits getDocsWithField(FieldInfo field) throws IOException {
  if (field.getDocValuesType() == FieldInfo.DocValuesType.SORTED_SET) {
    return DocValues.docsWithValue(getSortedSet(field), maxDoc);
  } else {
    return new Bits.MatchAllBits(maxDoc);
  }
}
 
开发者ID:lamsfoundation,项目名称:lams,代码行数:9,代码来源:Lucene42DocValuesProducer.java

示例4: setNextReader

import org.apache.lucene.util.Bits; //导入方法依赖的package包/类
@Override
public FieldComparator<T> setNextReader(AtomicReaderContext context) throws IOException {
  if (missingValue != null) {
    docsWithField = FieldCache.DEFAULT.getDocsWithField(context.reader(), field);
    // optimization to remove unneeded checks on the bit interface:
    if (docsWithField instanceof Bits.MatchAllBits) {
      docsWithField = null;
    }
  } else {
    docsWithField = null;
  }
  return this;
}
 
开发者ID:lamsfoundation,项目名称:lams,代码行数:14,代码来源:FieldComparator.java

示例5: ramBytesUsed

import org.apache.lucene.util.Bits; //导入方法依赖的package包/类
@Override
public long ramBytesUsed() {
  long base = RamUsageEstimator.NUM_BYTES_OBJECT_REF;
  if (bits instanceof Bits.MatchAllBits || bits instanceof Bits.MatchNoBits) {
    return base;
  } else {
    return base + (bits.length() >>> 3);
  }
}
 
开发者ID:lamsfoundation,项目名称:lams,代码行数:10,代码来源:FieldCacheImpl.java

示例6: getDocsWithField

import org.apache.lucene.util.Bits; //导入方法依赖的package包/类
/** Returns a Bits for a reader's docsWithField (potentially merging on-the-fly) 
 * <p>
 * This is a slow way to access this bitset. Instead, access them per-segment
 * with {@link AtomicReader#getDocsWithField(String)}
 * </p> 
 * */
public static Bits getDocsWithField(final IndexReader r, final String field) throws IOException {
  final List<AtomicReaderContext> leaves = r.leaves();
  final int size = leaves.size();
  if (size == 0) {
    return null;
  } else if (size == 1) {
    return leaves.get(0).reader().getDocsWithField(field);
  }

  boolean anyReal = false;
  boolean anyMissing = false;
  final Bits[] values = new Bits[size];
  final int[] starts = new int[size+1];
  for (int i = 0; i < size; i++) {
    AtomicReaderContext context = leaves.get(i);
    Bits v = context.reader().getDocsWithField(field);
    if (v == null) {
      v = new Bits.MatchNoBits(context.reader().maxDoc());
      anyMissing = true;
    } else {
      anyReal = true;
      if (v instanceof Bits.MatchAllBits == false) {
        anyMissing = true;
      }
    }
    values[i] = v;
    starts[i] = context.docBase;
  }
  starts[size] = r.maxDoc();

  if (!anyReal) {
    return null;
  } else if (!anyMissing) {
    return new Bits.MatchAllBits(r.maxDoc());
  } else {
    return new MultiBits(values, starts, false);
  }
}
 
开发者ID:lamsfoundation,项目名称:lams,代码行数:45,代码来源:MultiDocValues.java

示例7: getDocsWithField

import org.apache.lucene.util.Bits; //导入方法依赖的package包/类
@Override
public Bits getDocsWithField(FieldInfo field) throws IOException {
    if (VersionFieldMapper.NAME.equals(field.name)) {
        return new Bits.MatchAllBits(reader.maxDoc());
    } else {
        return in.getDocsWithField(field);
    }
}
 
开发者ID:baidu,项目名称:Elasticsearch,代码行数:9,代码来源:VersionFieldUpgrader.java

示例8: getDocsWithField

import org.apache.lucene.util.Bits; //导入方法依赖的package包/类
@Override
public Bits getDocsWithField(FieldInfo field) throws IOException {
  return new Bits.MatchAllBits(state.segmentInfo.getDocCount());
}
 
开发者ID:lamsfoundation,项目名称:lams,代码行数:5,代码来源:Lucene40DocValuesReader.java


注:本文中的org.apache.lucene.util.Bits.MatchAllBits方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。