i am comming hexo

感觉挺好的额, 终于有了自己的博客, 加油哦.

/**

  • Buffers input from an {@link InputStream} for reading lines.
    *
  • This class is used for buffered reading of lines. For purposes of this class, a line ends

  • with “n” or “rn”. End of input is reported by throwing {@code EOFException}. Unterminated
  • line at end of input is invalid and will be ignored, the caller may use {@code
  • hasUnterminatedLine()} to detect it after catching the {@code EOFException}.
    *
  • This class is intended for reading input that strictly consists of lines, such as line-based

  • cache entries or cache journal. Unlike the {@link java.io.BufferedReader} which in conjunction
  • with {@link java.io.InputStreamReader} provides similar functionality, this class uses different
  • end-of-input reporting and a more restrictive definition of a line.
    *
  • This class supports only charsets that encode ‘r’ and ‘n’ as a single byte with value 13

  • and 10, respectively, and the representation of no other character contains these values.
  • We currently check in constructor that the charset is one of US-ASCII, UTF-8 and ISO-8859-1.
  • The default charset is US_ASCII.
    */
    public class StrictLineReader implements Closeable {
    private static final byte CR = (byte) ‘r’;
    private static final byte LF = (byte) ‘n’;

    private final InputStream in;
    private final Charset charset;

    /*

    • Buffered data is stored in {@code buf}. As long as no exception occurs, 0 <= pos <= end
    • and the data in the range [pos, end) is buffered for reading. At end of input, if there is
    • an unterminated line, we set end == -1, otherwise end == pos. If the underlying
    • {@code InputStream} throws an {@code IOException}, end may remain as either pos or -1.
      */
      private byte[] buf;
      private int pos;
      private int end;

      /**

    • Constructs a new {@code LineReader} with the specified charset and the default capacity.
      *
    • @param in the {@code InputStream} to read data from.
    • @param charset the charset used to decode data. Only US-ASCII, UTF-8 and ISO-8859-1 are
    • supported.
    • @throws NullPointerException if {@code in} or {@code charset} is null.
    • @throws IllegalArgumentException if the specified charset is not supported.
      */
      public StrictLineReader(InputStream in, Charset charset) {
      this(in, 8192, charset);
      }

      /**

    • Constructs a new {@code LineReader} with the specified capacity and charset.
      *
    • @param in the {@code InputStream} to read data from.
    • @param capacity the capacity of the buffer.
    • @param charset the charset used to decode data. Only US-ASCII, UTF-8 and ISO-8859-1 are
    • supported.
    • @throws NullPointerException if {@code in} or {@code charset} is null.
    • @throws IllegalArgumentException if {@code capacity} is negative or zero
    • or the specified charset is not supported.
      */
      public StrictLineReader(InputStream in, int capacity, Charset charset) {
      if (in == null || charset == null) {

      throw new NullPointerException();
      

      }
      if (capacity < 0) {

      throw new IllegalArgumentException("capacity <= 0");
      

      }
      if (!(charset.equals(Charset.forName(“US-ASCII”)))) {

      throw new IllegalArgumentException("Unsupported encoding");
      

      }

      this.in = in;
      this.charset = charset;
      buf = new byte[capacity];
      }

      /**

    • Closes the reader by closing the underlying {@code InputStream} and
    • marking this reader as closed.
      *
    • @throws IOException for errors when closing the underlying {@code InputStream}.
      */
      public void close() throws IOException {
      synchronized (in) {

      if (buf != null) {
          buf = null;
          in.close();
      }
      

      }
      }

      /**

    • Reads the next line. A line ends with {@code “n”} or {@code “rn”},
    • this end of line marker is not included in the result.
      *
    • @return the next line from the input.
    • @throws IOException for underlying {@code InputStream} errors.
    • @throws EOFException for the end of source stream.
      */
      public String readLine() throws IOException {
      synchronized (in) {

      if (buf == null) {
          throw new IOException("LineReader is closed");
      }
      
      // Read more data if we are at the end of the buffered data.
      // Though it's an error to read after an exception, we will let {@code fillBuf()}
      // throw again if that happens; thus we need to handle end == -1 as well as end == pos.
      if (pos >= end) {
          fillBuf();
      }
      // Try to find LF in the buffered data and return the line if successful.
      for (int i = pos; i != end; ++i) {
          if (buf[i] == LF) {
              int lineEnd = (i != pos && buf[i - 1] == CR) ? i - 1 : i;
              String res = new String(buf, pos, lineEnd - pos, charset.name());
              pos = i + 1;
              return res;
          }
      }
      
      // Let's anticipate up to 80 characters on top of those already read.
      ByteArrayOutputStream out = new ByteArrayOutputStream(end - pos + 80) {
          @Override
          public String toString() {
              int length = (count > 0 && buf[count - 1] == CR) ? count - 1 : count;
              try {
                  return new String(buf, 0, length, charset.name());
              } catch (UnsupportedEncodingException e) {
                  throw new AssertionError(e); // Since we control the charset this will never happen.
              }
          }
      };
      
      while (true) {
          out.write(buf, pos, end - pos);
          // Mark unterminated line in case fillBuf throws EOFException or IOException.
          end = -1;
          fillBuf();
          // Try to find LF in the buffered data and return the line if successful.
          for (int i = pos; i != end; ++i) {
              if (buf[i] == LF) {
                  if (i != pos) {
                      out.write(buf, pos, i - pos);
                  }
                  pos = i + 1;
                  return out.toString();
              }
          }
      }
      

      }
      }

      public boolean hasUnterminatedLine() {
      return end == -1;
      }

      /**

    • Reads new input data into the buffer. Call only with pos == end or end == -1,
    • depending on the desired outcome if the function throws.
      */
      private void fillBuf() throws IOException {
      int result = in.read(buf, 0, buf.length);
      if (result == -1) {
      throw new EOFException();
      

      }
      pos = 0;
      end = result;
      }
      }