亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? parallelreader.java

?? lucene完整源碼
?? JAVA
字號:
package org.apache.lucene.index;/** * 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 java.io.IOException;import java.util.ArrayList;import java.util.Collection;import java.util.Enumeration;import java.util.HashSet;import java.util.Iterator;import java.util.List;import java.util.Map;import java.util.Set;import java.util.SortedMap;import java.util.TreeMap;import org.apache.lucene.document.Document;import org.apache.lucene.document.Field;/** An IndexReader which reads multiple, parallel indexes.  Each index added * must have the same number of documents, but typically each contains * different fields.  Each document contains the union of the fields of all * documents with the same document number.  When searching, matches for a * query term are from the first index added that has the field. * * <p>This is useful, e.g., with collections that have large fields which * change rarely and small fields that change more frequently.  The smaller * fields may be re-indexed in a new index and both indexes may be searched * together. *  * <p><strong>Warning:</strong> It is up to you to make sure all indexes * are created and modified the same way. For example, if you add * documents to one index, you need to add the same documents in the * same order to the other indexes. <em>Failure to do so will result in * undefined behavior</em>. */public class ParallelReader extends IndexReader {  private List readers = new ArrayList();  private SortedMap fieldToReader = new TreeMap();  private List storedFieldReaders = new ArrayList();   private int maxDoc;  private int numDocs;  private boolean hasDeletions; /** Construct a ParallelReader. */  public ParallelReader() throws IOException { super(null); }     /** Add an IndexReader. */  public void add(IndexReader reader) throws IOException {    add(reader, false);  } /** Add an IndexReader whose stored fields will not be returned.  This can  * accellerate search when stored fields are only needed from a subset of  * the IndexReaders.  *   * @throws IllegalArgumentException if not all indexes contain the same number   *     of documents  * @throws IllegalArgumentException if not all indexes have the same value   *     of {@link IndexReader#maxDoc()}  */  public void add(IndexReader reader, boolean ignoreStoredFields)    throws IOException {    if (readers.size() == 0) {      this.maxDoc = reader.maxDoc();      this.numDocs = reader.numDocs();      this.hasDeletions = reader.hasDeletions();    }    if (reader.maxDoc() != maxDoc)                // check compatibility      throw new IllegalArgumentException        ("All readers must have same maxDoc: "+maxDoc+"!="+reader.maxDoc());    if (reader.numDocs() != numDocs)      throw new IllegalArgumentException        ("All readers must have same numDocs: "+numDocs+"!="+reader.numDocs());        Iterator i = reader.getFieldNames(IndexReader.FieldOption.ALL).iterator();    while (i.hasNext()) {                         // update fieldToReader map      String field = (String)i.next();      if (fieldToReader.get(field) == null)        fieldToReader.put(field, reader);    }    if (!ignoreStoredFields)      storedFieldReaders.add(reader);             // add to storedFieldReaders    readers.add(reader);  }  public int numDocs() { return numDocs; }  public int maxDoc() { return maxDoc; }  public boolean hasDeletions() { return hasDeletions; }  // check first reader  public boolean isDeleted(int n) {    if (readers.size() > 0)      return ((IndexReader)readers.get(0)).isDeleted(n);    return false;  }  // delete in all readers  protected void doDelete(int n) throws IOException {    for (int i = 0; i < readers.size(); i++) {      ((IndexReader)readers.get(i)).deleteDocument(n);    }    hasDeletions = true;  }  // undeleteAll in all readers  protected void doUndeleteAll() throws IOException {    for (int i = 0; i < readers.size(); i++) {      ((IndexReader)readers.get(i)).undeleteAll();    }    hasDeletions = false;  }  // append fields from storedFieldReaders  public Document document(int n) throws IOException {    Document result = new Document();    for (int i = 0; i < storedFieldReaders.size(); i++) {      IndexReader reader = (IndexReader)storedFieldReaders.get(i);      Enumeration fields = reader.document(n).fields();      while (fields.hasMoreElements()) {        result.add((Field)fields.nextElement());      }    }    return result;  }  // get all vectors  public TermFreqVector[] getTermFreqVectors(int n) throws IOException {    ArrayList results = new ArrayList();    Iterator i = fieldToReader.entrySet().iterator();    while (i.hasNext()) {      Map.Entry e = (Map.Entry)i.next();      String field = (String)e.getKey();      IndexReader reader = (IndexReader)e.getValue();      TermFreqVector vector = reader.getTermFreqVector(n, field);      if (vector != null)        results.add(vector);    }    return (TermFreqVector[])      results.toArray(new TermFreqVector[results.size()]);  }  public TermFreqVector getTermFreqVector(int n, String field)    throws IOException {    IndexReader reader = ((IndexReader)fieldToReader.get(field));    return reader==null ? null : reader.getTermFreqVector(n, field);  }  public boolean hasNorms(String field) throws IOException {    IndexReader reader = ((IndexReader)fieldToReader.get(field));    return reader==null ? false : reader.hasNorms(field);  }  public byte[] norms(String field) throws IOException {    IndexReader reader = ((IndexReader)fieldToReader.get(field));    return reader==null ? null : reader.norms(field);  }  public void norms(String field, byte[] result, int offset)    throws IOException {    IndexReader reader = ((IndexReader)fieldToReader.get(field));    if (reader!=null)      reader.norms(field, result, offset);  }  protected void doSetNorm(int n, String field, byte value)    throws IOException {    IndexReader reader = ((IndexReader)fieldToReader.get(field));    if (reader!=null)      reader.doSetNorm(n, field, value);  }  public TermEnum terms() throws IOException {    return new ParallelTermEnum();  }  public TermEnum terms(Term term) throws IOException {    return new ParallelTermEnum(term);  }  public int docFreq(Term term) throws IOException {    IndexReader reader = ((IndexReader)fieldToReader.get(term.field()));    return reader==null ? 0 : reader.docFreq(term);  }  public TermDocs termDocs(Term term) throws IOException {    return new ParallelTermDocs(term);  }  public TermDocs termDocs() throws IOException {    return new ParallelTermDocs();  }  public TermPositions termPositions(Term term) throws IOException {    return new ParallelTermPositions(term);  }  public TermPositions termPositions() throws IOException {    return new ParallelTermPositions();  }  protected void doCommit() throws IOException {    for (int i = 0; i < readers.size(); i++)      ((IndexReader)readers.get(i)).commit();  }  protected synchronized void doClose() throws IOException {    for (int i = 0; i < readers.size(); i++)      ((IndexReader)readers.get(i)).close();  }  public Collection getFieldNames (IndexReader.FieldOption fieldNames) {    Set fieldSet = new HashSet();    for (int i = 0; i < readers.size(); i++) {      IndexReader reader = ((IndexReader)readers.get(i));      Collection names = reader.getFieldNames(fieldNames);      fieldSet.addAll(names);    }    return fieldSet;  }  private class ParallelTermEnum extends TermEnum {    private String field;    private TermEnum termEnum;    public ParallelTermEnum() throws IOException {      field = (String)fieldToReader.firstKey();      if (field != null)        termEnum = ((IndexReader)fieldToReader.get(field)).terms();    }    public ParallelTermEnum(Term term) throws IOException {      field = term.field();      IndexReader reader = ((IndexReader)fieldToReader.get(field));      if (reader!=null)        termEnum = reader.terms(term);    }    public boolean next() throws IOException {      if (termEnum == null)        return false;      boolean next = termEnum.next();      // still within field?      if (next && termEnum.term().field() == field)        return true;                              // yes, keep going      termEnum.close();                           // close old termEnum      // find the next field, if any      field = (String)fieldToReader.tailMap(field).firstKey();      if (field != null) {        termEnum = ((IndexReader)fieldToReader.get(field)).terms();        return true;      }      return false;                               // no more fields    }    public Term term() {      if (termEnum==null)        return null;      return termEnum.term();    }    public int docFreq() {      if (termEnum==null)        return 0;      return termEnum.docFreq();    }    public void close() throws IOException {      if (termEnum!=null)        termEnum.close();    }  }  // wrap a TermDocs in order to support seek(Term)  private class ParallelTermDocs implements TermDocs {    protected TermDocs termDocs;    public ParallelTermDocs() {}    public ParallelTermDocs(Term term) throws IOException { seek(term); }    public int doc() { return termDocs.doc(); }    public int freq() { return termDocs.freq(); }    public void seek(Term term) throws IOException {      IndexReader reader = ((IndexReader)fieldToReader.get(term.field()));      termDocs = reader!=null ? reader.termDocs(term) : null;    }    public void seek(TermEnum termEnum) throws IOException {      seek(termEnum.term());    }    public boolean next() throws IOException {      if (termDocs==null)        return false;      return termDocs.next();    }    public int read(final int[] docs, final int[] freqs) throws IOException {      if (termDocs==null)        return 0;      return termDocs.read(docs, freqs);    }    public boolean skipTo(int target) throws IOException {      if (termDocs==null)        return false;      return termDocs.skipTo(target);    }    public void close() throws IOException {      if (termDocs!=null)        termDocs.close();    }  }  private class ParallelTermPositions    extends ParallelTermDocs implements TermPositions {    public ParallelTermPositions() {}    public ParallelTermPositions(Term term) throws IOException { seek(term); }    public void seek(Term term) throws IOException {      IndexReader reader = ((IndexReader)fieldToReader.get(term.field()));      termDocs = reader!=null ? reader.termPositions(term) : null;    }    public int nextPosition() throws IOException {      // It is an error to call this if there is no next position, e.g. if termDocs==null      return ((TermPositions)termDocs).nextPosition();    }  }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品免费视频人成| 亚洲国产综合在线| 日韩av不卡在线观看| 成人小视频在线| 久久99久久99| 国产麻豆9l精品三级站| 大桥未久av一区二区三区中文| 福利一区在线观看| 亚洲成人av中文| 久久综合久久综合九色| 91亚洲资源网| 国产一区二区三区四| 亚洲一区二区视频在线| 日韩精品在线一区二区| 成人免费观看男女羞羞视频| 午夜影院在线观看欧美| 国产精品污网站| 欧美一区二区美女| 色综合久久久久综合体 | 久久久不卡网国产精品二区| 成人avav影音| 国产成人精品aa毛片| 欧美日韩亚洲高清一区二区| 免费成人美女在线观看| 激情另类小说区图片区视频区| 麻豆国产精品视频| 成人国产精品免费观看视频| jvid福利写真一区二区三区| 一本一本大道香蕉久在线精品| 成人高清免费观看| 99精品国产热久久91蜜凸| 欧美日韩精品欧美日韩精品一 | 成人一区二区三区在线观看| 成人av在线资源网站| 91农村精品一区二区在线| 欧美性xxxxxx少妇| 日韩免费观看高清完整版在线观看| 精品国内片67194| 综合电影一区二区三区| 亚洲午夜精品17c| 国产一区二区三区精品欧美日韩一区二区三区 | 国产精品视频一区二区三区不卡| 国产午夜亚洲精品不卡| 日本va欧美va瓶| 6080午夜不卡| 青青草国产成人99久久| 日韩欧美在线1卡| 夜夜嗨av一区二区三区四季av| 久久精品999| 欧美一区二区三区在线观看| 亚洲视频一区二区在线| 免费高清成人在线| 欧美日韩视频专区在线播放| 亚洲国产经典视频| 国产一区二区三区综合| 日韩一区二区三区在线观看| 亚洲夂夂婷婷色拍ww47 | 亚洲777理论| k8久久久一区二区三区| 久久久99精品免费观看不卡| 一区二区三区国产豹纹内裤在线| 菠萝蜜视频在线观看一区| 这里只有精品电影| 国产精品视频一二三| 国内成人精品2018免费看| 欧美激情一区二区三区全黄| 一区二区三区欧美日| 国产精品自拍网站| 成人国产一区二区三区精品| 中文字幕精品一区二区精品绿巨人 | 欧美一级在线观看| 日韩精品一区二区三区视频播放 | 蜜臀av一区二区| 欧美性猛交xxxxxxxx| 久久九九影视网| 精品一区二区三区av| 日韩欧美精品在线视频| 午夜精品一区在线观看| 91一区二区三区在线观看| 亚洲视频在线一区二区| 成人综合婷婷国产精品久久免费| 欧美电影免费观看高清完整版在线| 天天色天天爱天天射综合| 欧美卡1卡2卡| 美日韩黄色大片| 久久先锋资源网| 99re成人精品视频| 日本午夜一区二区| 欧美国产日产图区| 欧美性高清videossexo| 精品亚洲免费视频| 中文字幕一区二区三区av| 欧美日韩一区二区在线观看视频 | 日韩精品成人一区二区三区| 欧美一区二区视频在线观看2020| 久久99热这里只有精品| 精品精品国产高清a毛片牛牛| 色综合久久中文综合久久97| 婷婷成人激情在线网| 午夜成人在线视频| 亚洲人妖av一区二区| 欧美亚洲日本一区| 国产自产v一区二区三区c| 亚洲男人电影天堂| 日韩欧美国产1| 99精品久久99久久久久| 精品亚洲国产成人av制服丝袜| 一区二区理论电影在线观看| 欧美mv和日韩mv的网站| 在线视频欧美区| 国产精品自拍三区| 老司机免费视频一区二区| 久久久亚洲精华液精华液精华液| 91影院在线免费观看| 精品一区二区三区影院在线午夜| 亚洲黄色录像片| 国产精品二三区| 精品国产人成亚洲区| 色综合久久综合网欧美综合网 | 免费人成网站在线观看欧美高清| 亚洲卡通动漫在线| 国产精品视频yy9299一区| 亚洲精品一区二区三区蜜桃下载 | 欧美日韩一区在线| 91官网在线免费观看| voyeur盗摄精品| 色综合天天综合在线视频| 91美女在线看| aaa亚洲精品一二三区| 欧美高清在线视频| 国产婷婷色一区二区三区在线| 91小视频在线免费看| 国内成+人亚洲+欧美+综合在线| 国产精品三级av在线播放| 久久久99精品久久| 日韩久久久精品| 日韩欧美国产电影| 久久精品一区八戒影视| 精品久久久久av影院| 国产欧美中文在线| 国产欧美日韩另类一区| 日韩毛片视频在线看| 亚洲欧美国产三级| 污片在线观看一区二区| 另类人妖一区二区av| 色综合久久久久网| 在线视频中文字幕一区二区| 日韩美女视频一区二区在线观看| 国产亚洲精品超碰| 亚洲男人的天堂在线aⅴ视频| 亚洲国产色一区| 国产激情精品久久久第一区二区| 欧美色老头old∨ideo| 日韩一二三区视频| 中文字幕一区av| 五月综合激情网| 国产精品一区2区| 欧美日本在线看| 久久免费看少妇高潮| 亚洲一区二区三区美女| 国产精品69久久久久水密桃| 欧美最猛黑人xxxxx猛交| 精品欧美久久久| 一区二区三区国产精品| 国产一区二区伦理片| 91精品国产乱| 亚洲一区二区三区四区的| 成人黄色一级视频| 精品欧美乱码久久久久久 | 日韩欧美你懂的| 亚洲成va人在线观看| 国内精品嫩模私拍在线| 日韩一区二区精品葵司在线| 亚洲福中文字幕伊人影院| 国产传媒欧美日韩成人| 精品国产三级电影在线观看| 欧美aaa在线| 国产香蕉久久精品综合网| 国产大片一区二区| 久久久久久97三级| 国产精品亚洲а∨天堂免在线| 欧美日韩中文精品| 裸体一区二区三区| 91精品国产麻豆| 久久99久久精品欧美| 久久众筹精品私拍模特| 蜜桃久久久久久| 欧美成人一区二区三区| 成人免费毛片app| 成人欧美一区二区三区| 97久久精品人人爽人人爽蜜臀| 国产精品麻豆视频| 色999日韩国产欧美一区二区| 亚洲午夜精品网| 欧美一区二区人人喊爽| 国产美女一区二区| 亚洲精品成a人| 欧美一区二区福利在线| 精品99一区二区三区| 奇米一区二区三区|