JavaIO——内存操作流、打印流
我们之前所做的都是对文件进行IO处理,实则我们也可以对内存进行IO处理。我们将发生在内存中的IO处理称为内存流。
内存操作流也可分为两类:字节内存流和字符内存流。
(1)ByteArrayInputStream 和 ByteArrayOutputStream
构造函数:
public class ByteArrayOutputStream extends OutputStream
public class ByteArrayInputStream extends InputStream
(2)CharArrayInputStream 和 CharArrayOutputStream
构造函数:
public class CharArrayWriter extends Writer
public class CharArrayReader extends Reader
由此我们可以得出内存流的继承关系:
利用内存流实现大小写转换:
-
package myIO;
-
-
import java.io.ByteArrayInputStream;
-
import java.io.ByteArrayOutputStream;
-
import java.io.IOException;
-
import java.io.InputStream;
-
import java.io.OutputStream;
-
-
/*通过内存流实现大小写转换
-
* */
-
public class Test3 {
-
public static void main(String[] args) throws IOException {
-
String string = "hello world,hello lemon";
-
//实例化InputStream对象,进行实例化时应将需要操作的数据保存在内存中,读取的将是设置的内容
-
InputStream inputStream = new ByteArrayInputStream(string.getBytes());
-
//实例化OutputStream对象
-
OutputStream outputStream = new ByteArrayOutputStream();
-
int temp= 0;
-
//判断是否读完
-
while((temp = inputStream.read())!=-1) {
-
//对每个字节进行处理,处理之后存在于OutputStream类中
-
//进行大小写转换
-
outputStream.write(Character.toUpperCase(temp));
-
}
-
//直接对outputStream对象进行输出
-
System.out.println(outputStream);
-
//关闭流
-
inputStream.close();
-
outputStream.close();
-
-
}
-
}
(2)内存流的操作
内存流有个很小的功能就是实现两个文件的合并操作(对很小的文件而言)。
内存流最核心的就是:将所有OutputStream输出的程序保存在了程序中,所以可以利用这一特征来进行处理。
-
/*
-
* 实现两个文件的合并处理
-
* */
-
public class Test3{
-
public static void main(String[] args) throws IOException {
-
String singal = File.separator;
-
//指明要合并两个文件的地址
-
File[] files = new File[] {
-
-
new File("C:"+singal+"Users"+singal+"lenovo"+singal+"Desktop"+singal+"Test1.txt")
-
,new File("C:"+singal+"Users"+singal+"lenovo"+singal+"Desktop"+singal+"Test2.txt")};
-
String[] data = new String[2];
-
for(int i = 0 ;i <files.length;i++) {
-
data[i] = readFile(files[i]);
-
}
-
StringBuffer stringBuffer = new StringBuffer();
-
String contentA [] = data[0].split(" ") ;
-
String contentB [] = data[1].split(" ") ;
-
for (int i = 0; i < contentA.length ; i++) {
-
stringBuffer.append(contentA[i]).append("(").append(contentB[i]).append(")").append(" ") ;
-
}
-
System.out.println(stringBuffer);
-
}
-
//读取文件内容,使用File对象因为其包含完整的路径信息
-
public static String readFile(File file) throws IOException {
-
if(file.exists()) {
-
InputStream inputStream = new FileInputStream(file);
-
//没有向上转型,因为后续要使用toByteArray()方法
-
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
-
int temp = 0;
-
byte[] data = new byte[10];
-
while((temp = inputStream.read(data))!=-1) {
-
//将数据保存在byteArrayOutputStream
-
byteArrayOutputStream.write(data,0,temp);
-
}
-
byteArrayOutputStream.close();
-
inputStream.close();
-
return new String(byteArrayOutputStream.toByteArray());
-
}
-
return null;
-
}
-
}
2、打印流
打印流的本质是解决OutputStream的缺陷,因为若想将非二进制的数据通过程序向终端目标直接输出信息的话,OutputStream有如下缺陷:所有的数据都要转换成字节数组,若要输出int、double更是不方便。
(1)进行简单打印流的设计
-
/*
-
* 设计简单打印流
-
* */
-
class PrintDesign{
-
private OutputStream outputStream;
-
//构造函数
-
//有外部传入要输出的目的终端
-
public PrintDesign(OutputStream outputStream) {
-
super();
-
this.outputStream = outputStream;
-
}
-
//实现输出的功能(传入参数为字符串)
-
public void print(String string) throws IOException {
-
this.outputStream.write(string.getBytes());
-
}
-
//实现换行功能
-
public void println(String string) throws IOException {
-
this.print(string+"\r\n");
-
}
-
//传入参数为int
-
public void print(int data) throws IOException {
-
this.print(String.valueOf(data));
-
}
-
public void println(int data) throws IOException {
-
this.print(String.valueOf(data)+"\r\n");
-
}
-
}
-
public class Test3{
-
public static void main(String[] args) throws IOException {
-
String singal = File.separator;
-
PrintDesign printDesign = new PrintDesign(new FileOutputStream(
-
new File("C:"+singal+"Users"+singal+"lenovo"+singal+"Desktop"+singal+"Test1.txt")));
-
printDesign.println("姓名:");
-
printDesign.print("lemon");
-
printDesign.println("年龄:");
-
printDesign.print(20);
-
}
-
}
我们可以发现经过简单的处理使得OutputStream的功能变得更加强大了,其实我们所做的工作只不过是对OutputStream做了一个封装而已。实则java中提供有专门的打印流处理类:字节打印流rintStream、字符打印流PrintWriter.
(2)认识打印流处理类
字节打印流:public class PrintStream extends FilterOutputStream
构造函数:public PrintStream(OutputStream out)
字符打印流:public class PrintWriter extends Writer
构造函数:public PrintWriter(OutputStream out)
public PrintWriter (Writer out)
打印流的设计模式属于装饰者设计模式:核心是某个类的功能,但是为了得到更好的操作效果,让其支持的功能更多一些。
(3)打印流的使用
在后续的应用中字符打印流(PrintWriter)引用比较对,因为它可以接收Writer和OutputStream两种类型的参数;而字节打印流(PrintStream)只可接收OutputStream类型的参数。
-
/*
-
* 字符打印流的使用
-
* */
-
public class Test3{
-
public static void main(String[] args) throws FileNotFoundException {
-
String singal = File.separator;
-
PrintWriter printWriter = new PrintWriter(
-
new File("C:"+singal+"Users"+singal+"lenovo"+singal+"Desktop"+singal+"Test1.txt"));
-
printWriter.print("班级:");
-
printWriter.println("数学152");
-
printWriter.println("年龄:");
-
printWriter.println(20);
-
printWriter.close();
-
-
}
-
}
(4)格式化输出
我们在C语言遇到一个printf()函数,这个函数在输出的时候可以使用一些占位符,例如:字符串(%s)、数字(%d)、小数 (%f)、字符(%c)等。从JDK1.5开始,PrintStream类中也追加了此种操作。
格式化输出:public PrintStream printf(String format, Object ... args)
-
/*
-
* 格式化输出
-
* */
-
public class Test3{
-
public static void main(String[] args) throws FileNotFoundException {
-
String name = "lemon";
-
int age = 20;
-
double salary = 10.3;
-
String singal = File.separator;
-
PrintStream printStream = new PrintStream(new FileOutputStream(
-
new File("C:"+singal+"Users"+singal+"lenovo"+singal+"Desktop"+singal+"Test2.txt")));
-
printStream.printf("姓名:%s,年龄:%d,工资:%f",name,age,salary);
-
printStream.close();
-
}
-
}
JavaIO——内存操作流、打印流的更多相关文章
- IO流的Properties集合,序列化流与反序列化流,打印流及commons-IO
内容介绍 Properties集合 序列化流与反序列化流 打印流 commons-IO Properties类 Properties类介绍 Properties 类表示了一个持久的属性集.Proper ...
- Java API —— IO流(数据操作流 & 内存操作流 & 打印流 & 标准输入输出流 & 随机访问流 & 合并流 & 序列化流 & Properties & NIO)
1.操作基本数据类型的流 1) 操作基本数据类型 · DataInputStream:数据输入流允许应用程序以与机器无关方式从底层输入流中读取基本 Java 数据类型.应用程序可以使用数据输出 ...
- 6.5(java学习笔记)其他流(字节数组流,数据流,对象流,打印流)
一.字节数组流 之前使用输入输出流的操作的对象是文件,而这里字节数组流操作的对象是内存,内存可以看做是一个字节数组. 使用字节数组流读写就可以看做是从内存A到内存B的读写,对象时内存即字节数组. 1. ...
- java 转换流 打印流 数据流
转换流 InputStreamReader 和 OutputStreamWriter处理流用于将字节流转化成字符流,字符流与字节流之间的桥梁InputStreamReader 的作用是把 InputS ...
- Properties-转换流-打印流-序列化和反序列化-Commons-IO工具类
一.Properties 类(java.util) 概述:Properties 是一个双列集合;Properties 属于map的特殊的孙子类;Properties 类没有泛型,propert ...
- JAVA笔记12__字节、字符缓冲流/打印流/对象流/
/** * !!:以后写流的时候一定要加入缓冲!! * 对文件或其它目标频繁的读写操作,效率低,性能差. * 缓冲流:好处是能更高效地读写信息,原理是将数据先缓冲起来,然后一起写入或读取出来. * * ...
- python3 subprocess 内存操作视频转换流格式
import subprocessout = open('./tmp/sss.mp4','rb').read()p = subprocess.Popen(["./ffmpeg",& ...
- 021.10 IO流 打印流
内容:PrintStream:字节流 PrintWriter:字符流 PrintStream public static void main(String[] args) throws IOEx ...
- 34 io流-- 打印流和对象流
概述 io流分为字符流和字节流,具体分类相见下图 字符流:char 一些基本文本的数据传输 字节流:byte 图片.视频等用文本查看器查看不了的文件都是二进制文件,只能用字节流传输,使用字符流cp的看 ...
随机推荐
- dns+nginx实现多虚拟主机
借鉴于朋友的需求,公司需要启用域名访问内部的业务系统,现实情况是内部的业务系统目前使用的是单主机,单nginx多端口的方式再运行,朋友最终想实现启用域名方式问题,且域名不需要用户手工输入端口号 两种思 ...
- SpringCloud 2020.0.4 系列之 Bus
1. 概述 老话说的好:会休息的人才更会工作,身体是革命的本钱,身体垮了,就无法再工作了. 言归正传,之前我们聊了 SpringCloud 的 分布式配置中心 Config,文章里我们聊了config ...
- .net core api 请求实现接口幂等性
简单实现接口幂等性,根据参数的hascode实现: 参数介绍 WaitMillisecond : 请求等待毫秒数 CacheMillisecond:请求结果缓存毫秒数 参数具体使用场景 WaitMi ...
- redis客户端修改了key-value对之后有时会报MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist o...错误,不能持久化
解决方案,连接redis客户端 redis目录下:redis-cli -h 127.0.0.1 -p 6379-h后为redis服务器ip,-p后为端口号进入redis-client之后输入命令 co ...
- stom消费kafka消息速度慢的问题
原来代码如下 KafkaSpoutConfig<String, String> kafkaSpoutConfig = KafkaSpoutConfig.builder(kafka_serv ...
- JS中如何将yyyy-MM-dd HH:mm:ss格式的字符串转成Date类型
var deadline = '2019-04-11 13:11:00'; var result = new Date(deadline.replace(/-/g, '/'));
- sql关联修改
UPDATE p set p.ClientID = c.id from PaymentTable p left JOIN ClientTable c on p.ClientID = c.Clie ...
- ICCV2021 | Vision Transformer中相对位置编码的反思与改进
前言 在计算机视觉中,相对位置编码的有效性还没有得到很好的研究,甚至仍然存在争议,本文分析了相对位置编码中的几个关键因素,提出了一种新的针对2D图像的相对位置编码方法,称为图像RPE(IRPE). ...
- Maven 依赖调解源码解析(一):开篇
本文是系列文章<Maven 源码解析:依赖调解是如何实现的?>第一篇,主要做个开头介绍.并为后续的实验做一些准备.系列文章总目录参见:https://www.cnblogs.com/xia ...
- [bzoj4557]侦察守卫
令g[i][j]表示覆盖了i的子树中距离i大于等于j的所有点,f[i][j]表示覆盖了i的子树和子树外距离i小于等于j的所有点,有递推式$f[i][j]=min(f[i][j]+g[son][j],f ...