字节流:

package com.wz.thread.stream;

import java.io.PipedOutputStream;

/**
 * 字节输入流
 * @author Administrator
 *
 */
public class WriteData {

    
    public void writeMethod(PipedOutputStream out) {
        try {
            System.out.println("write:");
            for(int i = 0; i < 200; i++) {
                String outData = "" + ( i + 1 );
                out.write(outData.getBytes());
                System.out.print(outData);
            }
            System.out.println();
            out.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
package com.wz.thread.stream;

import java.io.PipedInputStream;

/**
 * 字节输出流
 * @author Administrator
 *
 */
public class ReadData {
    
    public void readMethod(PipedInputStream input) {
        try {
            System.out.println("read:");
            byte[] byteArray = new byte[20];
            int readLength = input.read(byteArray);
            while(-1 != readLength) {
                String newData = new String(byteArray, 0, readLength);
                System.out.print(newData);
                readLength = input.read(byteArray);
            }
            System.out.println();
            input.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}
package com.wz.thread.stream;
/**
 * 写入流线程
 * @author Administrator
 *
 */

import java.io.PipedOutputStream;

public class ThreadWrite extends Thread{
    
    private WriteData write;
    private PipedOutputStream out;
    public ThreadWrite(WriteData write, PipedOutputStream out) {
        super();
        this.write = write;
        this.out = out;
    }
    
    @Override
    public void run() {
        super.run();
        write.writeMethod(out);
    }

}
package com.wz.thread.stream;
/**
 * 读出流线程
 * @author Administrator
 *
 */

import java.io.PipedInputStream;

public class ThreadRead extends Thread{
    
    private ReadData read;
    private PipedInputStream input;
    public ThreadRead(ReadData read, PipedInputStream input) {
        super();
        this.read = read;
        this.input = input;
    }
    
    @Override
    public void run() {
        super.run();
        read.readMethod(input);
    }
    
}
package com.wz.thread.stream;

import java.io.PipedInputStream;
import java.io.PipedOutputStream;

/**
 *
 * @author Administrator
 *
 */
public class Run {
    
    public static void main(String[] args) {
        try {
            WriteData write = new WriteData();
            ReadData read = new ReadData();
            
            PipedOutputStream out = new PipedOutputStream();
            PipedInputStream input = new PipedInputStream();
            // 这个是相互建立连接
            input.connect(out);
            //out.connect(input);
            
            ThreadWrite threadWrite = new ThreadWrite(write, out);
            ThreadRead threadRead = new ThreadRead(read, input);
            
            // 先读再写  更好的看出效果
            threadRead.start();
            Thread.sleep(2000);
            threadWrite.start();
            
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}
字符流:
package com.wz.thread.readerandwrite;

import java.io.PipedWriter;

/**
 * 字符输入流
 * @author Administrator
 *
 */
public class WriteData {

    
    public void writeMethod(PipedWriter out) {
        try {
            System.out.println("write:");
            for(int i = 0; i < 200; i++) {
                String outData = "" + ( i + 1 );
                out.write(outData);
                System.out.print(outData);
            }
            System.out.println();
            out.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
package com.wz.thread.readerandwrite;

import java.io.PipedReader;

/**
 * 字符输出流
 * @author Administrator
 *
 */
public class ReadData {
    
    public void readMethod(PipedReader input) {
        try {
            System.out.println("read:");
            char[] byteArray = new char[20];
            int readLength = input.read(byteArray);
            while(-1 != readLength) {
                String newData = new String(byteArray, 0, readLength);
                System.out.print(newData);
                readLength = input.read(byteArray);
            }
            System.out.println();
            input.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}
package com.wz.thread.readerandwrite;
/**
 * 写入流线程
 * @author Administrator
 *
 */

import java.io.PipedWriter;

public class ThreadWrite extends Thread{
    
    private WriteData write;
    private PipedWriter out;
    public ThreadWrite(WriteData write, PipedWriter out) {
        super();
        this.write = write;
        this.out = out;
    }
    
    @Override
    public void run() {
        super.run();
        write.writeMethod(out);
    }

}
package com.wz.thread.readerandwrite;
/**
 * 读出流线程
 * @author Administrator
 *
 */

import java.io.PipedReader;

public class ThreadRead extends Thread{
    
    private ReadData read;
    private PipedReader input;
    public ThreadRead(ReadData read, PipedReader input) {
        super();
        this.read = read;
        this.input = input;
    }
    
    @Override
    public void run() {
        super.run();
        read.readMethod(input);
    }
    
}
package com.wz.thread.readerandwrite;

import java.io.PipedReader;
import java.io.PipedWriter;

/**
 *
 * @author Administrator
 *
 */
public class Run {
    
    public static void main(String[] args) {
        try {
            WriteData write = new WriteData();
            ReadData read = new ReadData();
            
            PipedWriter out = new PipedWriter();
            PipedReader input = new PipedReader();
            // 这个是相互建立连接
            input.connect(out);
            //out.connect(input);
            
            ThreadWrite threadWrite = new ThreadWrite(write, out);
            ThreadRead threadRead = new ThreadRead(read, input);
            
            // 先读再写  更好的看出效果
            threadRead.start();
            Thread.sleep(2000);
            threadWrite.start();
            
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}

java多线程的字符流与字节流的更多相关文章

  1. java学习之字符流与字节流的转换

    package com.io; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundExce ...

  2. Java——文件操作字符流和字节流的区别

    转:http://blog.csdn.net/joephoenix/articles/2283165.aspx java的IO流分两种流 字节流 InputStream OutputStream 字符 ...

  3. Java IO编程——字符流与字节流

    在java.io包里面File类是唯一 一个与文件本身有关的程序处理类,但是File只能够操作文件本身而不能够操作文件的内容,或者说在实际的开发之中IO操作的核心意义在于:输入与输出操作.而对于程序而 ...

  4. 理解Java中字符流与字节流的区别

    1. 什么是流 Java中的流是对字节序列的抽象,我们可以想象有一个水管,只不过现在流动在水管中的不再是水,而是字节序列.和水流一样,Java中的流也具有一个“流动的方向”,通常可以从中读入一个字节序 ...

  5. Java字符流和字节流对文件操作

    记得当初自己刚开始学习Java的时候,对Java的IO流这一块特别不明白,所以写了这篇随笔希望能对刚开始学习Java的人有所帮助,也方便以后自己查询.Java的IO流分为字符流(Reader,Writ ...

  6. Java中字符流与字节流的区别

    字符流处理的单元为2个字节的Unicode字符,分别操作字符.字符数组或字符串,而字节流处理单元为1个字节,操作字节和字节数组.所以字符流是由Java虚拟机将字节转化为2个字节的Unicode字符为单 ...

  7. Java基础---IO(一)---IO流概述、字符流、字节流、流操作规律

    第一讲     IO概述 概述 1.IO流:即InputOutput的缩写. 2.特点: 1)IO流用来处理设备间的数据传输. 2)Java对数据的操作是通过流的方式. 3)Java用于操作流的对象都 ...

  8. Java基础:IO流之字节流和字符流

    1. 流的概念 流(stream)的概念源于UNIX中管道(pipe)的概念.在UNIX中,管道是一条不间断的字节流,用来实现程序或进程间的通信,或读写外围设备.外部文件等. 一个流,必有源端和目的端 ...

  9. [Java] I/O底层原理之一:字符流、字节流及其源码分析

    关于 I/O 的类可以分为四种: 关于字节的操作:InputStream 和 OutPutStream: 关于字符的操作:Writer 和 Reader: 关于磁盘的操作:File: 关于网络的操作: ...

随机推荐

  1. java设计模式-State(状态)模式

    state定义     不同的状态,不同的行为;或者说,每个状态有着相应的行为.         就像电风扇的开关,一档的上一个是关闭,关闭的上一个是五档,五档的上一个是四档,以此类推,而且五档的下一 ...

  2. sqlserver 简单的创建数据库

    简简单单,作为不是牛逼的程序来说,这是很容易忘记的sql语句: use mastergo --判断是否存在该数据库if exists(select *from Sysdatabases where n ...

  3. 软件工程网络15团队作业1——团队组队&展示

    Deadline: 2018-3-25 10:00PM,以提交至班级博客时间为准. 申请开通团队博客,并将团队博客地址发表在本次随笔的评论中 团队展示 根据5-6人的组队要求,每个队伍创建团队博客并发 ...

  4. C语言第二周作业

    一.PTA实验作业 题目一:7-1 计算分段函数 1.实验代码 double x,y; scanf("%lf", &x); if(x >= 0){ y=pow(x,0 ...

  5. django 连接mysql

    环境 Linux 修改工程目录下的settings.py 文件 #!!!!!!!!切勿出现中文 即便//注释也不行 DATABASES = { 'default': { 'ENGINE': 'djan ...

  6. Flask 部署和分发

    到目前为止,启动Flask应用都是通过"app.run()"方法,在开发环境中,这样固然可行,不过到了生产环境上,势必需要采用一个健壮的,功能强大的Web应用服务器来处理各种复杂情 ...

  7. LeetCode & Q121-Best Time to Buy and Sell Stock-Easy

    Array DP Description: Say you have an array for which the ith element is the price of a given stock ...

  8. js 防止重复点击

    1.添加flag 适用于ajax 表单提交,提交之前flag = false , 提及中,true ,提交后false 2.事件重复点击: <script> var throttle = ...

  9. Hazelcast分布式

    一般的应用正式环境中都不止一台服务器(也就是说是集群的),那么如果只是简单的将数据预加载到内存,那么就会有数据不同步的现象. (更新了其中一台JVM,另一台JVM并不会收到通知从而保持数据同步). 这 ...

  10. __all__

    相信很多人第一次见到这个__all__都很好奇,他有什么作用 那他到底有什么作用呢? 先上代码 from scrapy.utils.reqser import request_to_dict, req ...