⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tokenstream.java

📁 lucene-2.4.0 是一个全文收索的工具包
💻 JAVA
字号:
package org.apache.lucene.analysis;/** * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements.  See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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.index.Payload;import java.io.IOException;/** A TokenStream enumerates the sequence of tokens, either from  fields of a document or from query text.  <p>  This is an abstract class.  Concrete subclasses are:  <ul>  <li>{@link Tokenizer}, a TokenStream  whose input is a Reader; and  <li>{@link TokenFilter}, a TokenStream  whose input is another TokenStream.  </ul>  NOTE: subclasses must override {@link #next(Token)}.  It's  also OK to instead override {@link #next()} but that  method is now deprecated in favor of {@link #next(Token)}.  */public abstract class TokenStream {  /** Returns the next token in the stream, or null at EOS.   *  @deprecated The returned Token is a "full private copy" (not   *  re-used across calls to next()) but will be slower   *  than calling {@link #next(Token)} instead.. */  public Token next() throws IOException {    final Token reusableToken = new Token();    Token nextToken = next(reusableToken);    if (nextToken != null) {      Payload p = nextToken.getPayload();      if (p != null) {        nextToken.setPayload((Payload) p.clone());      }    }    return nextToken;  }  /** Returns the next token in the stream, or null at EOS.   *  When possible, the input Token should be used as the   *  returned Token (this gives fastest tokenization   *  performance), but this is not required and a new Token   *  may be returned. Callers may re-use a single Token   *  instance for successive calls to this method.   *  <p>   *  This implicitly defines a "contract" between    *  consumers (callers of this method) and    *  producers (implementations of this method    *  that are the source for tokens):   *  <ul>   *   <li>A consumer must fully consume the previously    *       returned Token before calling this method again.</li>   *   <li>A producer must call {@link Token#clear()}   *       before setting the fields in it & returning it</li>   *  </ul>   *  Also, the producer must make no assumptions about a   *  Token after it has been returned: the caller may   *  arbitrarily change it.  If the producer needs to hold   *  onto the token for subsequent calls, it must clone()   *  it before storing it.   *  Note that a {@link TokenFilter} is considered a consumer.   *  @param reusableToken a Token that may or may not be used to   *  return; this parameter should never be null (the callee   *  is not required to check for null before using it, but it is a   *  good idea to assert that it is not null.)   *  @return next token in the stream or null if end-of-stream was hit   */  public Token next(final Token reusableToken) throws IOException {    // We don't actually use inputToken, but still add this assert    assert reusableToken != null;    return next();  }  /** Resets this stream to the beginning. This is an   *  optional operation, so subclasses may or may not   *  implement this method. Reset() is not needed for   *  the standard indexing process. However, if the Tokens    *  of a TokenStream are intended to be consumed more than    *  once, it is necessary to implement reset().  Note that   *  if your TokenStream caches tokens and feeds them back   *  again after a reset, it is imperative that you   *  clone the tokens when you store them away (on the   *  first pass) as well as when you return them (on future   *  passes after reset()).   */  public void reset() throws IOException {}    /** Releases resources associated with this stream. */  public void close() throws IOException {}}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -