`
sungang_1120
  • 浏览: 309560 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类

Guava API学习之CharSequenceReader

阅读更多

 

      CharSequenceReader类是以CharSequence的形式读取字符。CharSequenceReader类继承自Reader类,除了remaining()、hasRemaining()以及checkOpen()函数之后,其他的函数都是重写Reader类中的函数。

 

 

注:CharSequenceReader类声明没有用public关键字,所以我们暂时还不能调用这个类

CharSequenceReader类有下面三个成员变量

private CharSequence seq; 	//存放字符序列
private int pos;			//存放上述字符序列的下一次读
private int mark;			//可以记录pos的位置,用于下一次重置到pos位置

 CharSequenceReader类只有一个构造函数如下:

 public CharSequenceReader(CharSequence seq) {
     this.seq = checkNotNull(seq);
 }

 这个函数非常的简单,就是将seq赋值给CharSequenceReader类的seq,使得其他方法可以操作seq。

private void checkOpen() throws IOException {
      if (seq == null) {
          throw new IOException("reader closed");
      }
  }

  private boolean hasRemaining() {
      return remaining() > 0;
  }

  private int remaining() {
      return seq.length() - pos;
}

     上面三个函数是CharSequenceReader类专有的。checkOpen()函数主要是判断seq是否没有被清空,如果被清空了,抛出空指针异 常;否则什么事都不做。其他的函数实现几乎都用到了checkOpen。hasRemaining函数主要是判断当前是否还有数据可以读。在 CharSequenceReader类中提供了三个用于读seq中数据的函数,原型如下:

public synchronized int read(CharBuffer target) throws IOException
public synchronized int read() throws IOException
public synchronized int read(char[] cbuf, int off, int len) throws IOException

 上述上个函数都是重写自Reader类相关的函数,read(CharBuffer target) 函数实现如下:

@Override
public synchronized int read(CharBuffer target) throws IOException {
    checkNotNull(target);
    checkOpen();
    if (!hasRemaining()) {
        return -1;
    }
    int charsToRead = Math.min(target.remaining(), remaining());
    for (int i = 0; i < charsToRead; i++) {
        target.put(seq.charAt(pos++));
    }
    return charsToRead;
}

  先判断seq中是否没被清空;接着判断seq中还有数据可读与否,如果没有数据可读,将返回-1,;否则得到target和seq的最小可读空间大小, 并从seq读取相应的数据于target中。其实target.put函数是将一个字符存放在内部char数组的相应位置上面去。read函数最后返回本 次读取字符的个数。read()函数实现如下:

@Override
public synchronized int read() throws IOException {
    checkOpen();
    return hasRemaining() ? seq.charAt(pos++) : -1;
}

 可以看出,这个函数实现相当的简单,先判断seq中是否没被清空;接着判断seq中还有数据可读与否,如果有数据可读,则返回seq中下标为pos的数 据,且pos向后移动一个位置;如果没有数据可读,则之间返回-1。read()函数最多只返回一个字符。read(char[] cbuf, int off, int len) 函数实现如下:

@Override
public synchronized int read(char[] cbuf, int off, int len) 
                                    throws IOException {
        checkPositionIndexes(off, off + len, cbuf.length);
        checkOpen();
        if (!hasRemaining()) {
            return -1;
        }

        int charsToRead = Math.min(len, remaining());
        for (int i = 0; i < charsToRead; i++) {
            cbuf[off + i] = seq.charAt(pos++);
        }
        return charsToRead;
}

      大题和read(CharBuffer target)函数实现类似。它主要是将读取的到字符存放在cbuf下标从off开始的位置,并且依次读取charsToRead个,最后返回本次读取到的字符个数。
   接下来说说skip(long n)函数,它的实现如下:

 @Override
 public synchronized long skip(long n) throws IOException {
     checkArgument(n >= 0, "n (%s) may not be negative", n);
     checkOpen();
     // safe because remaining is an int
     int charsToSkip = (int) Math.min(remaining(), n); 
     pos += charsToSkip;
     return charsToSkip;
}

 主要是通过移动pos指标,从而达到忽略seq中charsToSkip 个字符。上面我们就说了CharSequenceReader类中大多数的函数都是重写Reader类的,阅读Reader类中的skip(long n)函数我们可以看到,它忽略了charsToSkip个字符的同时还保存了本次被忽略的charsToSkip个字符于char skipBuffer[]数组中。
 剩下的几个函数为:

  @Override
  public synchronized boolean ready() throws IOException {
      checkOpen();
      return true;
  }

  @Override
  public boolean markSupported() {
      return true;
  }

  @Override
  public synchronized void mark(int readAheadLimit) throws IOException {
      checkArgument(readAheadLimit >= 0, 
              "readAheadLimit (%s) may not be negative", readAheadLimit);
      checkOpen();
      mark = pos;
  }

  @Override
  public synchronized void reset() throws IOException {
      checkOpen();
      pos = mark;
  }

  @Override
  public synchronized void close() throws IOException {
      seq = null;
}

 都是比较简单的,ready()函数简单的判断seq是否没被清空,从而返回true或者抛出异常(见checkOpen()函数)。 markSupported()函数只是简单的标识CharSequenceReader类支持标记这个方法。mark函数主要是记录下seq当前的下 标。reset()函数是将当前的下标重置为mark。close()函数主要是清空seq中的数据。
  我们可以从源码中发现,CharSequenceReader类中绝大部分的函数都是用了synchronized 修饰的,这使得每一次只有一个线程执行相关的函数(完)

 

 

分享到:
评论

相关推荐

    guava-17.0-API文档-中文版.zip

    包含翻译后的API文档:guava-17.0-javadoc-API文档-中文(简体)版.zip; Maven坐标:com.google.guava:guava:17.0; 标签:google、guava、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开...

    guava-18.0-API文档-中文版.zip

    包含翻译后的API文档:guava-18.0-javadoc-API文档-中文(简体)版.zip 对应Maven信息:groupId:com.google.guava,artifactId:guava,version:18.0 使用方法:解压翻译后的API文档,用浏览器打开“index.html”...

    guava-20.0-API文档-中文版.zip

    包含翻译后的API文档:guava-20.0-javadoc-API文档-中文(简体)版.zip; Maven坐标:com.google.guava:guava:20.0; 标签:google、guava、jar包、java、中文文档; 使用方法:解压翻译后的API文档,用浏览器打开...

    guava-API文档

    guava-API文档

    guava-23.0-API文档-中文版.zip

    包含翻译后的API文档:guava-23.0-javadoc-API文档-中文(简体)版.zip; Maven坐标:com.google.guava:guava:23.0; 标签:google、guava、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开...

    guava-19.0-API文档-中英对照版.zip

    包含翻译后的API文档:guava-19.0-javadoc-API文档-中文(简体)-英语-对照版.zip; Maven坐标:com.google.guava:guava:19.0; 标签:google、guava、中英对照文档、jar包、java; 使用方法:解压翻译后的API文档,用...

    guava-27.0.1-jre-API文档-中文版.zip

    包含翻译后的API文档:guava-27.0.1-jre-javadoc-API文档-中文(简体)版.zip; Maven坐标:com.google.guava:guava:27.0.1-jre; 标签:google、guava、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用...

    Guava 23.0 API (CHM格式)

    Guava 23.0 API CHM格式,可以搜索,方便离线查阅。

    guava-12.0.1-API文档-中英对照版.zip

    包含翻译后的API文档:guava-12.0.1-javadoc-API文档-中文(简体)-英语-对照版.zip 对应Maven信息:groupId:com.google.guava,artifactId:guava,version:12.0.1 使用方法:解压翻译后的API文档,用浏览器打开...

    guava-28.0-android-API文档-中文版.zip

    包含翻译后的API文档:guava-28.0-android-javadoc-API文档-中文(简体)版.zip; Maven坐标:com.google.guava:guava:28.0-android; 标签:google、guava、中文文档、jar包、java; 使用方法:解压翻译后的API文档,...

    guava-18.0-API文档-中英对照版.zip

    赠送原API文档:guava-18.0-javadoc.jar 赠送源代码:guava-18.0-sources.jar 包含翻译后的API文档:guava-18.0-javadoc-API文档-中文(简体)-英语-对照版.zip 对应Maven信息:groupId:com.google.guava,...

    guava 常用API说明

    NULL 博文链接:https://whnqwe.iteye.com/blog/2313173

    guava-30.0-jre-API文档-中文版.zip

    包含翻译后的API文档:guava-30.0-jre-javadoc-API文档-中文(简体)版.zip; Maven坐标:com.google.guava:guava:30.0-jre; 标签:google、guava、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器...

    guava-16.0.1-API文档-中文版.zip

    包含翻译后的API文档:guava-16.0.1-javadoc-API文档-中文(简体)版.zip; Maven坐标:com.google.guava:guava:16.0.1; 标签:google、guava、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开...

    Guava 19 API ( CHM格式 )

    Guava 中文是石榴的意思,该项目是 Google 的一个开源项目,包含许多 Google 核心的 Java 常用库。 目前主要包含: com.google.common.annotations com.google.common.base com.google.common.collect ...

    guava学习知识点

    guava学习体系知识点的学习,归纳出来了知识点。根据知识点去学习可以快熟了解guava

    guava-25.0-jre-API文档-中文版.zip

    包含翻译后的API文档:guava-25.0-jre-javadoc-API文档-中文(简体)版.zip; Maven坐标:com.google.guava:guava:25.0-jre; 标签:google、guava、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器...

    guava-30.1.1-jre-API文档-中文版.zip

    包含翻译后的API文档:guava-30.1.1-jre-javadoc-API文档-中文(简体)版.zip; Maven坐标:com.google.guava:guava:30.1.1-jre; 标签:google、guava、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用...

    guava19_api_chm英文文档

    guava19_api_chm英文文档

Global site tag (gtag.js) - Google Analytics