• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >Java > PipedWriter和PipedReader源码分析_动力节点Java学院整理

PipedWriter和PipedReader源码分析_动力节点Java学院整理

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了pipedwriter,源码之家,源码,网站源码,易语言源码等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

PipedWriter和PipedReader源码分析

1. PipedWriter 源码(基于jdk1.7.40) 

package java.io;
 public class PipedWriter extends Writer {
   // 与PipedWriter通信的PipedReader对象
   private PipedReader sink;
   // PipedWriter的关闭标记
   private boolean closed = false;
   // 构造函数,指定配对的PipedReader
   public PipedWriter(PipedReader snk) throws IOException {
     connect(snk);
   }
   // 构造函数
   public PipedWriter() {
   }
   // 将“PipedWriter” 和 “PipedReader”连接。
   public synchronized void connect(PipedReader snk) throws IOException {
     if (snk == null) {
       throw new NullPointerException();
     } else if (sink != null || snk.connected) {
       throw new IOException("Already connected");
     } else if (snk.closedByReader || closed) {
       throw new IOException("Pipe closed");
     }
     sink = snk;
     snk.in = -1;
     snk.out = 0;
     // 设置“PipedReader”和“PipedWriter”为已连接状态
     // connected是PipedReader中定义的,用于表示“PipedReader和PipedWriter”是否已经连接
     snk.connected = true;
   }
   // 将一个字符c写入“PipedWriter”中。
   // 将c写入“PipedWriter”之后,它会将c传输给“PipedReader”
   public void write(int c) throws IOException {
     if (sink == null) {
       throw new IOException("Pipe not connected");
     }
     sink.receive(c);
   }
   // 将字符数组b写入“PipedWriter”中。
   // 将数组b写入“PipedWriter”之后,它会将其传输给“PipedReader”
   public void write(char cbuf[], int off, int len) throws IOException {
     if (sink == null) {
       throw new IOException("Pipe not connected");
     } else if ((off | len | (off + len) | (cbuf.length - (off + len))) < ) {
       throw new IndexOutOfBoundsException();
     }
     sink.receive(cbuf, off, len);
   }
   // 清空“PipedWriter”。
   // 这里会调用“PipedReader”的notifyAll();
   // 目的是让“PipedReader”放弃对当前资源的占有,让其它的等待线程(等待读取PipedWriter的线程)读取“PipedWriter”的值。
   public synchronized void flush() throws IOException {
     if (sink != null) {
       if (sink.closedByReader || closed) {
         throw new IOException("Pipe closed");
       }
       synchronized (sink) {
         sink.notifyAll();
       }
     }
   }
   // 关闭“PipedWriter”。
   // 关闭之后,会调用receivedLast()通知“PipedReader”它已经关闭。
   public void close() throws IOException {
     closed = true;
     if (sink != null) {
       sink.receivedLast();
     }
   }
 }
</div>

2. PipedReader 源码(基于jdk1.7.40)    

package java.io;
  public class PipedReader extends Reader {
    // “PipedWriter”是否关闭的标记
    boolean closedByWriter = false;
    // “PipedReader”是否关闭的标记
    boolean closedByReader = false;
    // “PipedReader”与“PipedWriter”是否连接的标记
    // 它在PipedWriter的connect()连接函数中被设置为true
   boolean connected = false;
   Thread readSide;  // 读取“管道”数据的线程
   Thread writeSide;  // 向“管道”写入数据的线程
   // “管道”的默认大小
  private static final int DEFAULT_PIPE_SIZE = 1024;
   // 缓冲区
   char buffer[];
   //下一个写入字符的位置。in==out代表满,说明“写入的数据”全部被读取了。
   int in = -;
   //下一个读取字符的位置。in==out代表满,说明“写入的数据”全部被读取了。
   int out = ;
   // 构造函数:指定与“PipedReader”关联的“PipedWriter”
   public PipedReader(PipedWriter src) throws IOException {
     this(src, DEFAULT_PIPE_SIZE);
   }
   // 构造函数:指定与“PipedReader”关联的“PipedWriter”,以及“缓冲区大小”
   public PipedReader(PipedWriter src, int pipeSize) throws IOException {
     initPipe(pipeSize);
     connect(src);
   }
   // 构造函数:默认缓冲区大小是1024字符
   public PipedReader() {
     initPipe(DEFAULT_PIPE_SIZE);
   }
   // 构造函数:指定缓冲区大小是pipeSize
   public PipedReader(int pipeSize) {
     initPipe(pipeSize);
   }
   // 初始化“管道”:新建缓冲区大小
   private void initPipe(int pipeSize) {
    if (pipeSize <= 0) {
       throw new IllegalArgumentException("Pipe size <= 0");
     }
     buffer = new char[pipeSize];
   }
   // 将“PipedReader”和“PipedWriter”绑定。
   // 实际上,这里调用的是PipedWriter的connect()函数
   public void connect(PipedWriter src) throws IOException {
     src.connect(this);
   }
   // 接收int类型的数据b。
   // 它只会在PipedWriter的write(int b)中会被调用
   synchronized void receive(int c) throws IOException {
     // 检查管道状态
     if (!connected) {
       throw new IOException("Pipe not connected");
     } else if (closedByWriter || closedByReader) {
       throw new IOException("Pipe closed");
     } else if (readSide != null && !readSide.isAlive()) {
       throw new IOException("Read end dead");
     }
     // 获取“写入管道”的线程
     writeSide = Thread.currentThread();
     // 如果“管道中被读取的数据,等于写入管道的数据”时,
    // 则每隔1000ms检查“管道状态”,并唤醒管道操作:若有“读取管道数据线程被阻塞”,则唤醒该线程。
     while (in == out) {
       if ((readSide != null) && !readSide.isAlive()) {
         throw new IOException("Pipe broken");
       }
       /* full: kick any waiting readers */
       notifyAll();
       try {
        wait(1000);
       } catch (InterruptedException ex) {
         throw new java.io.InterruptedIOException();
       }
     }
    if (in < 0) {
     in = 0;
      out = 0;
     }
     buffer[in++] = (char) c;
     if (in >= buffer.length) {
      in = 0;
     }
   }
   // 接收字符数组b。
   synchronized void receive(char c[], int off, int len) throws IOException {
     while (--len >= ) {
      receive(c[off++]);
     }
   }
   // 当PipedWriter被关闭时,被调用
   synchronized void receivedLast() {
     closedByWriter = true;
     notifyAll();
   }
   // 从管道(的缓冲)中读取一个字符,并将其转换成int类型
   public synchronized int read() throws IOException {
     if (!connected) {
       throw new IOException("Pipe not connected");
     } else if (closedByReader) {
       throw new IOException("Pipe closed");
     } else if (writeSide != null && !writeSide.isAlive()
          && !closedByWriter && (in < )) {
       throw new IOException("Write end dead");
     }
     readSide = Thread.currentThread();
    int trials = 2;
    while (in < 0) {
       if (closedByWriter) {
         /* closed by writer, return EOF */
         return -1;
       }
       if ((writeSide != null) && (!writeSide.isAlive()) && (--trials < )) {
         throw new IOException("Pipe broken");
       }
       /* might be a writer waiting */
       notifyAll();
       try {
        wait(1000);
       } catch (InterruptedException ex) {
         throw new java.io.InterruptedIOException();
       }
     }
     int ret = buffer[out++];
     if (out >= buffer.length) {
      out = 0;
     }
     if (in == out) {
       /* now empty */
      in = -1;
     }
     return ret;
   }
   // 从管道(的缓冲)中读取数据,并将其存入到数组b中
   public synchronized int read(char cbuf[], int off, int len) throws IOException {
     if (!connected) {
       throw new IOException("Pipe not connected");
     } else if (closedByReader) {
       throw new IOException("Pipe closed");
     } else if (writeSide != null && !writeSide.isAlive()
         && !closedByWriter && (in < 0)) {
       throw new IOException("Write end dead");
     }
    if ((off < 0) || (off > cbuf.length) || (len < 0) ||
      ((off + len) > cbuf.length) || ((off + len) < 0)) {
       throw new IndexOutOfBoundsException();
     } else if (len == 0) {
      return 0;
     }
     /* possibly wait on the first character */
  



 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • PipedWriter和PipedReader源码分析_动力节点Java学院整理
  • PipedWriter和PipedReader源码分析_动力节点Java学院整理

相关文章

  • 2017-05-28java容器详细解析
  • 2017-05-28Spring Boot启动过程完全解析(二)
  • 2017-05-28详解Spring 框架中切入点 pointcut 表达式的常用写法
  • 2017-05-28Spring-Boot框架初步搭建
  • 2017-05-28Java IO中字节流复制图片实现代码
  • 2017-05-28Spring Boot(五)之跨域、自定义查询及分页
  • 2017-05-28JAVA用户自定义事件监听实例代码
  • 2017-05-28java 中HashMap实现原理深入理解
  • 2017-05-28Java 生产者/消费者问题实例详解
  • 2017-05-28Java 中IO流字符流详解及实例

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • Spring boot 默认静态资源路径与手动配置访问路径的方法
    • 给Java菜鸟的一些建议_关于Java知识点归纳(J2EE and Web 部分)
    • Java中LinkedList详解和使用示例_动力节点Java学院整理
    • 初识Spring Boot框架和快速入门
    • spring boot配合前端实现跨域请求访问
    • Java线程的生命周期和状态控制_动力节点Java学院整理
    • Java的特点和优点(动力节点整理)
    • JavaWeb中web.xml初始化加载顺序详解
    • Java微信公众平台开发(5) 文本及图文消息回复的实现
    • java三层架构原理与作用小结

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有