一、字符串流

定义:字符串流,以一个字符为数据源,来构造一个字符流。

作用:在Web开发中,我们经常要从服务器上获取数据,数据返回的格式通常一个字符串(XML、JSON),我们需要把这个字符串构造为一个字符流。然后再用第三方数据解析器来解析数据。

代码示例:计算一个字符串有多少个单词

package IODemo;

import java.io.IOException;
import java.io.StreamTokenizer;
import java.io.StringReader;


/** 
 * 注意 有可能是面试题目
 *
 */

public class StringStreamDemo {

    private static void stringReader(){

        String str = "good good study day day up";
        StringReader sr = new StringReader(str);
        // 流的标记器(分析这个流里面的内容)  字符值用于查找字符的五个可能属性: 空格 , 字母 , 数字 , 字符串引号和注释字符 。 每个角色都可以有零个或多个这些属性。
        StreamTokenizer st = new StreamTokenizer(sr);
        int count = 0;
        // ttype 在读取后的这个标记类型等于结尾的话就要一直循环读
        while (st.ttype != StreamTokenizer.TT_EOF){
            try {
                //如果 读了这个流里面的内容的是一个单词的话 就累加
                if (st.nextToken() == StreamTokenizer.TT_WORD){
                    count++;
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        System.out.println("count="+count);
        sr.close();
    }



    public static void main(String[] args) {

        stringReader();
    }
}

 

二、管道流 

管道输入流:

PipedInputStream:
  • 管道输入流应连接到管道输出流; 管道输入流然后提供写入管道输出流的任何数据字节。
  • 典型地,数据被从一个读PipedInputStream对象由一个线程并且数据被写入到对应的PipedOutputStream通过一些其它线程。
  • 不建议尝试从单个线程使用这两个对象,因为它可能会使线程死锁。
  • 管道输入流包含一个缓冲区,在读取操作中将读取操作与限制内的操作相分离的管道被认为是broken如果正在提供的数据字节到连接的管道输出流中的线程不再存活。

 

管道输出流:

PipedOutputStream:
  • 管道输出流可以连接到管道输入流以创建通信管道。 管道输出流是管道的发送端。
  • 典型地,数据被写入到一个PipedOutputStream由一个线程对象和数据被从连接读取PipedInputStream通过一些其它线程。
  • 不建议尝试从单个线程使用这两个对象,因为它可能会使线程死锁。 管被说成是broken如果从连接读取数据字节的螺纹管道输入流不再存活。

 

代码示例:

package IODemo;

import java.io.IOException;
import java.io.StreamTokenizer;
import java.io.StringReader;


/**
 * 注意 有可能是面试题目
 *
 */
public class StringStreamDemo {

    private static void stringReader(){

        String str = "good good study day day up";
        StringReader sr = new StringReader(str);
        // 流的标记器(分析这个流里面的内容)  字符值用于查找字符的五个可能属性: 空格 , 字母 , 数字 , 字符串引号和注释字符 。 每个角色都可以有零个或多个这些属性。
        StreamTokenizer st = new StreamTokenizer(sr);
        int count = 0;
        // ttype 在读取后的这个标记类型等于结尾的话就要一直循环读
        while (st.ttype != StreamTokenizer.TT_EOF){
            try {
                //如果 读了这个流里面的内容的是一个单词的话 就累加
                if (st.nextToken() == StreamTokenizer.TT_WORD){
                    count++;
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        System.out.println("count="+count);
        sr.close();
    }



    public static void main(String[] args) {

        stringReader();
    }
}

 

 

 

 

版权声明:本文为lpss-75074038原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/lpss-75074038/p/12008584.html