java学习笔记之IO编程—内存流、管道流、随机流
1.内存操作流
之前学习的IO操作输入和输出都是从文件中来的,当然,也可以将输入和输出的位置设置在内存上,这就需要用到内存操作流,java提供两类内存操作流
- 字节内存操作流:ByteArrayOutputStream:将内存中数据输出 ByteArrayInputStream:将内容写入到内存中
- 字符内存操作流:CharArrayWriter CharArrayReader
使用场景:
假设现在需要实现IO操作,又不希望产生文件,则就可以以内存为终端进行处理,这个时候的流程
与文件IO不同,InputStream是往内存里写,OutputStream是读内存。
ByteArrayOutputStream类的定义:
public class ByteArrayOutputStream extends OutputStream
主要方法:

ByteArrayInputStream类的定义:
public class ByteArrayInputStream extends InputStream

代码实例:利用内存操作流实现一个小写字母转大写字母的操作
import java.io.*;
public class ByteArrayStreamDemo {
public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub
String str = "i believe i can fly";
ByteArrayOutputStream output = new ByteArrayOutputStream();
InputStream input = new ByteArrayInputStream(str.getBytes());
int data = 0;
while((data = input.read()) != -1) {
output.write(Character.toUpperCase(data));
}
byte res[] = output.toByteArray();
System.out.println(new String(res));
input.close();
output.close();
}
}
2.管道流
管道流主要作用是实现两个线程之间的IO处理操作,java中提供两类管道流
- 字节管道流:PipedInputStream(管道输入流) PipedOutputStream(管道输出流)
- 字符管道流:PipedReader PipedWriter
如果想要进行管道输出,则必须把输出流连在输入流之上,在PipeOutputStream上有如下方法用于连接管道。
public void connect(PipedInputStream src) throws IOException
在PipedReader上有如下方法用于连接管道。
public void connect(PipedWriter snk) throws IOException
PipedOutputStream类的定义:
public class PipedOutputStream extends OutputStream
构造方法:
public PipedOutputStream()
主要方法:
public void write(int b) throws IOException//输出方法
PipedInputStream类的定义:
public class PipedInputStream extends InputStream
构造方法:
public PipedInputStream()
主要方法:
public int read() throws IOException//输入方法
代码实例:
import java.io.*;
public class PipedDemo {
public static void main(String[] args) throws IOException {
// TODO Auto-generated method stub
SendThread send = new SendThread();
RecieveThread recieve = new RecieveThread();
send.getOutput().connect(recieve.getInput());
new Thread(send,"消息发送线程:").start();
new Thread(recieve,"消息接收线程:").start();
}
}
class SendThread implements Runnable{
private PipedOutputStream output;//管道输出流
public SendThread() {
this.output = new PipedOutputStream();//实例化管道输出流
}
@Override
public void run() {
// TODO Auto-generated method stub
for(int i=1;i<=10;i++) {
try {
this.output.write(("【第"+i+"次信息发送-" + Thread.currentThread().getName()+"i love you】\n").getBytes());
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
try {
this.output.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public PipedOutputStream getOutput() {
return output;
}
}
class RecieveThread implements Runnable{
private PipedInputStream input;//管道输入流
public RecieveThread() {
this.input = new PipedInputStream();//实例化管道输入流
}
@Override
public void run() {
// TODO Auto-generated method stub
byte[] data = new byte[1024];
int len = 0;
ByteArrayOutputStream bos = new ByteArrayOutputStream();
try {
while((len=this.input.read(data))!= -1) {
bos.write(data,0,len);
}
System.out.println("{"+Thread.currentThread().getName()+"接收消息}"+new String(bos.toByteArray()));
bos.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
this.input.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public PipedInputStream getInput() {
return input;
}
}
3.随机流(RandomAcceFile类)
对于文件内容的处理操作主要是通过InputStream(Reader)OutputStream(Write)来实现,但是利用这些类
实现的内容读取只能够将数据部分部分读取进来,如果文件非常庞大(20G),此时存再按照传统的IO操作进行读取
和分析根本不可能完成,所以这种情况下RandomAccessFile类可以实现跳跃式的读取,可以只读取中间的部分内容
(前提:需要有一个完善的保存形式)
RandomAccessFile类的定义:
public class RandomAccessFile extends Object
implements DataOutput, DataInput, Closeable
构造方法:
public RandomAccessFile(File file,String mode) throws FileNotFoundException
RandomAccessFile最大的特点实在数据的读取处理上,因为所有的数据时按照固定的长度进行的保存,所以读取的
时候就可以进行跳字节读取
主要方法:
public int skipBytes(int n) throws IOException//向下跳
public void seek(long pos) throws IOException//向回跳
代码实例:
/*
* 实现文件的保存
*/
package IODemo; import java.io.*; public class RandomAccessFileDemo { public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub
File file = new File("D:"+File.separator+"mldn.txt");
RandomAccessFile raf = new RandomAccessFile(file,"rw");
String[] names = new String[] {"zhangsan","wangwu ","lisi "};//名字占8位
int age[] = new int[] {30,20,16};//年龄占4位
for(int x = 0 ; x < names.length ; x++) {
raf.write(names[x].getBytes());
raf.writeInt(age[x]);
}
raf.close();
} }
/*
* 读取数据
*/
package IODemo; import java.io.*; public class RandomAccessFileDemo2 { public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub
File file = new File("D:"+File.separator+"mldn.txt");
RandomAccessFile raf = new RandomAccessFile(file,"rw");
{//读取lisi数据,跳过24位
raf.skipBytes(24);
byte[] data = new byte[8];
int len = raf.read(data);
System.out.println("姓名:"+new String(data,0,len).trim()+"年龄:"+raf.readInt());
}
{//读取wangwu数据,回跳12位
raf.seek(12);
byte[] data = new byte[8];
int len = raf.read(data);
System.out.println("姓名:"+new String(data,0,len).trim()+"年龄:"+raf.readInt());
}
{//读取zhangsan数据,回跳到顶点
raf.seek(0);
byte[] data = new byte[8];
int len = raf.read(data);
System.out.println("姓名:"+new String(data,0,len).trim()+"年龄:"+raf.readInt());
}
} }
整体的使用之中由用户自行定义要读取的位置,而后按照指定的结构进行数据的读取
java学习笔记之IO编程—内存流、管道流、随机流的更多相关文章
- java学习笔记之IO编程—字节流和字符流
1. 流的基本概念 在java.io包里面File类是唯一一个与文件本身有关的程序处理类,但是File只能够操作文件本身而不能操作文件的内容,或者说在实际的开发之中IO操作的核心意义在于:输入与输出操 ...
- java学习笔记之IO编程—打印流和BufferedReader
1.打印流(PrintWriter) 想要通过程序实现内容输出,其核心一定是要依靠OutputStream类,但是OutputStream类有一个最大缺点,就是这个类中的输出操作功能有限,所有的数据一 ...
- java学习笔记之IO编程—对象序列化
对象序列化就是将内存中保存的对象以二进制数据流的形式进行处理,可以实现对象的保存或网络传输. 并不是所有的对象都可以被序列化,如果要序列化的对象,那么对象所在的类一定要实现java.io.Serial ...
- java学习笔记之IO编程—目录和文件的拷贝
进行文件或目录的拷贝时,要先判断处理对象是文件还是目录,如果是文件则直接拷贝,如果是目录还需要拷贝它的子目录及其文件,这就需要递归处理了 import java.io.*; class FileUti ...
- java学习笔记之IO编程—File文件操作类
1. File类说明 在Java语言里面提供有对于文件操作系统操作的支持,而这个支持就在java.io.File类中进行了定义,也就是说在整个java.io包里面,File类是唯一一个与文件本身操作( ...
- java学习笔记15--多线程编程基础2
本文地址:http://www.cnblogs.com/archimedes/p/java-study-note15.html,转载请注明源地址. 线程的生命周期 1.线程的生命周期 线程从产生到消亡 ...
- java学习笔记14--多线程编程基础1
本文地址:http://www.cnblogs.com/archimedes/p/java-study-note14.html,转载请注明源地址. 多线程编程基础 多进程 一个独立程序的每一次运行称为 ...
- 【原】Java学习笔记033 - IO
package cn.temptation; public class Sample01 { public static void main(String[] args) { // 需求:继承关系中爷 ...
- Java学习笔记-10.io流
1.输入流,只能从中读取数据,而不能向其写出数据.输出流,只能想起写入字节数据,而不能从中读取. 2.InputStream的类型有: ByteArrayInputStream 包含一个内存缓冲区,字 ...
随机推荐
- 01 web api接口
WEB API接口 接口介绍 接口概念:前台与后台进行信息交互的媒介 - url连接 https://api.map.baidu.com/place/v2/search 接口组成: url链接 - 长 ...
- VMware克隆Linux虚拟机报错
在VMware里克隆了2个centos6.5,执行命令重启网卡服务报以下错误: Bringing up interface eth0: Device eth0 does not seem to be ...
- 通配符与标签!important的背景展示,也是让我怀疑人生了
是谁在耳边对我说!important提升权重优先级,只为这一句,我用了3600s研究通配符与标签!important的背景展示,也是让我怀疑人生了!选择器权值:标签选择器1,类选择器和伪类选择器:10 ...
- CentOS7 GlusterFS文件系统部署
一.GlusterFS简介 GlusterFS(GNU ClusterFile System)是一种全对称的开源分布式文件系统,所谓全对称是指GlusterFS采用弹性哈希算法,没有中心节点,所有节点 ...
- O2O外卖玩众包 开放平台难解标准之痛
开放平台难解标准之痛" title="O2O外卖玩众包 开放平台难解标准之痛"> 有一种怪现象一直是国内互联网企业摆脱不了的附骨之疽--不管规模大小,总是削尖了脑 ...
- Python和Anoconda和Pycharm联合使用教程
简介 Python是一种跨平台的计算机程序设计语言.是一种面向对象的动态类型语言,最初被设计用于编写自动化脚本(shell),随着版本的不断更新和语言新功能的添加,越多被用于独立的.大型项目的开发. ...
- request.getParameterMap获取不到数据问题
最近在做javaweb项目的过程中发现使用request.getParameterMap( )方法获取jsp页面中的表单数据的时候发现获取不到,检查了好长时间最后发现问题是在jsp页面中. reque ...
- idea 编译报错 Build completed with 1 error and 0 warnings in 2 s 113 ms
settings里java compiler改成正确版本 project structure里同样如此
- P1028 数的计算( 记忆剪枝 )
题目描述 我们要求找出具有下列性质数的个数(包含输入的自然数 n ): 先输入一个自然数 n(n≤1000),然后对此自然数按照如下方法进行处理: 不作任何处理; 在它的左边加上一个自然数,但该自然数 ...
- 【python基础语法】元祖、字典、集合、数据类型的分类(第4天课堂笔记)
""" 列表:可变数据类型,对列表内部的元素可以进行修改 元祖: tuple,不可变数据类型,是不可以进行增删查改 元祖的方法: count 查找元素的数量 index ...