Java学习笔记-10.io流
1.输入流,只能从中读取数据,而不能向其写出数据。输出流,只能想起写入字节数据,而不能从中读取。
2.InputStream的类型有:
ByteArrayInputStream 包含一个内存缓冲区,字节从中取出。
FileInputStream 从文件中获得字节。
ObjectInputStream 用来恢复被序列化的对象。
PipedInputStream 管道输入流,读取管道内容。多和PipedOutputStream一起用于多线程通信。
SequenceInputStream 是多种输入流的逻辑串联,从第一个输入流读取,直到最后一个输入流。
StringBufferInputStream 读取的字节由字符串提供。
2.OutputStream类型也有如下:
ByteArrayOutputStream 该类实现了一个输出流,其数据被写入由byte数组充当的缓冲区,缓冲区会随着数据的不断写入而自动增长。
FileOutputStream 该类实现了一个输出流,其数据写入文件。
ObjectOutputStream 该类将实现了序列化的对象序列化后写入指定地方。
PipedOutputStream 管道的输出流,是管道的发送端。
3.Objectstream,InputStream经常会和FileInputStream和FileOutputStream一起用。(初始化时用)
ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("Logon.out"));
4.File类并不是指一个文件,也代表一系列文件的名字,如果代表一个文件集,可用list()方法查询这个集。
5.StreamTokenizer用于将任何InputStream分割为一系列几号,StringTokenizer提供了与 StreamTokenizer极相似的功能,不过是针对字符串的,感觉和C#的split()方法类似。
6.用Zip对文件进行压缩时的步骤:
首先生成压缩文件:
FileOutputStream f =
new FileOutputStream("test.zip");
CheckedOutputStream csum =
new CheckedOutputStream(
f, new Adler32());
ZipOutputStream out =
new ZipOutputStream(
new BufferedOutputStream(csum));
out.setComment("A test of Java Zipping");//压缩文件注释信息
然后要把要压缩的文件添加进去:
out.putNextEntry(new ZipEntry(test.txt);
之后如果有需要还可以继续向文件中写入别的东西,但必须保证out类中已经有ZipEntry类了。
源代码:
import java.io.*;
import java.util.*;
import java.util.zip.*; public class ZipCompress {
public static void main(String[] args) {
try {
FileOutputStream fileOutputStream = new FileOutputStream("test.zip");
CheckedOutputStream csum = new CheckedOutputStream(fileOutputStream, new Adler32());
ZipOutputStream outputStream = new ZipOutputStream(new BufferedOutputStream(csum));
outputStream.setComment("A test of java Zipping");
System.out.println("Writing file" + "zip.txt");
BufferedReader in = new BufferedReader(new FileReader("zip.txt"));
outputStream.putNextEntry(new ZipEntry("zip.txt"));
// int c;
// while ((c = in.read()) != -1) {
// outputStream.write(c);
// }
// in.close();
outputStream.write("123".getBytes());
outputStream.close();
System.out.println("Checksum:" + csum.getChecksum().getValue());
System.out.println("Reading file");
FileInputStream fileInputStream = new FileInputStream("test.zip");
CheckedInputStream csumi = new CheckedInputStream(fileInputStream, new Adler32());
ZipInputStream in2 = new ZipInputStream(new BufferedInputStream(csumi));
ZipEntry zipEntry;
System.out.println("Checksum:" + csumi.getChecksum().getValue());
while ((zipEntry = in2.getNextEntry()) != null) {
System.out.println("Reading file:" + zipEntry);
int x;
while ((x = in2.read()) != -1) {
System.out.println(x);
} } in2.close(); ZipFile zf = new ZipFile("test.zip");
Enumeration e = zf.entries();
while (e.hasMoreElements()) {
ZipEntry ze2 = (ZipEntry) e.nextElement();
System.out.println("File: " + ze2);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
7.Serialization和Externalizable接口的区别,两者都是可以对类进行序列化的接口,不同的是Serialization默认会把对象的所有全都序列化,而Externalizable是可以对序列化的部分进行控制,也就是部分序列化。
8.serialization控制序列化的方法:(1)应用transient(临时)关键字。
(2)我们可以实现 Serializable接口,并添加(注意是“添加”,而非“覆盖”或者“实现”)名为writeObject()和 readObject()的方法。一旦对象被序列化或者重新装配,就会分别调用那两个方法。
Java学习笔记-10.io流的更多相关文章
- java学习笔记16--I/O流和文件
本文地址:http://www.cnblogs.com/archimedes/p/java-study-note16.html,转载请注明源地址. IO(Input Output)流 IO流用来处理 ...
- 【原】Java学习笔记033 - IO
package cn.temptation; public class Sample01 { public static void main(String[] args) { // 需求:继承关系中爷 ...
- JavaSE 学习笔记之IO流(二十二)
IO流:用于处理设备上数据. 流:可以理解数据的流动,就是一个数据流.IO流最终要以对象来体现,对象都存在IO包中. 流也进行分类: 1:输入流(读)和输出流(写). 2:因为处理的数据不同,分为字节 ...
- Java学习笔记--文件IO
简介 对于任何程序设计语言,输入和输出(Input\Output)都是系统非常核心的功能,程序运行需要数据,而数据的获取往往需要跟外部系统进行通信,外部系统可能是文件.数据库.其他程序.网络.IO设备 ...
- java学习笔记之IO编程—内存流、管道流、随机流
1.内存操作流 之前学习的IO操作输入和输出都是从文件中来的,当然,也可以将输入和输出的位置设置在内存上,这就需要用到内存操作流,java提供两类内存操作流 字节内存操作流:ByteArrayOutp ...
- Java编程思想学习笔记_5(IO流)
一.用DataInputStream读取字符 可以使用available方法查看还有多少可供存取的字符.示例如下: public class Test1 { public static void ma ...
- java学习笔记之IO编程—字节流和字符流
1. 流的基本概念 在java.io包里面File类是唯一一个与文件本身有关的程序处理类,但是File只能够操作文件本身而不能操作文件的内容,或者说在实际的开发之中IO操作的核心意义在于:输入与输出操 ...
- java学习笔记之IO编程—打印流和BufferedReader
1.打印流(PrintWriter) 想要通过程序实现内容输出,其核心一定是要依靠OutputStream类,但是OutputStream类有一个最大缺点,就是这个类中的输出操作功能有限,所有的数据一 ...
- Java学习笔记之——IO
一. IO IO读写 流分类: 按照方向:输入流(读),输出流(写) 按照数据单位:字节流(传输时以字节为单位),字符流(传输时以字符为单位) 按照功能:节点流,过滤流 四个抽象类: InputStr ...
随机推荐
- Notes 20180306 : 变量与常量
1.1 变量与常量 我们在开发中会经常听到常量和变量,那么常量和变量指的又是什么呢?顾名思义,在程序执行过程中,其值不能被改变的量称为常量,其值能被改变的量称为变量.变量与常量的命名都必须使用合法的标 ...
- 增加oracle表空间
查找用户对应的表空间 1.查询表空间物理文件路径select tablespace_name, file_id, file_name,round(bytes/(1024*1024),0) total_ ...
- CentOS7 yum命令
1.yum 清理缓存 [hado@localhost /]# yum clean all [hado@localhost /]# rm -rf /var/cache/yum/*
- Redis服务端和客户端的命令
服务器端 服务器端的命令为redis-server 可以使⽤help查看帮助⽂档 redis-server --help 个人习惯 ps aux | grep redis 查看redis服务器进程su ...
- python字符编码转换说明及深浅copy介绍
编码说明: 常用编码介绍: ascii 数字,字母 特殊字符. 字节:8位表示一个字节. 字符:是你看到的内容的最小组成单位. abc : a 一个字符. 中国:中 一个字符. a : 0000 10 ...
- Java 8 – Map排序
前提 Map是Java中最常用的集合类之一,这里整理了关于HashMap的排序 (关于List的排序,请查看Collections.sort()的doc或源码). 将无序的HashMap借助Strea ...
- fastdfs安装过程
Fastdfs于centos7的安装步骤(支持横向拓展) 主要目的:根据网上教程搭建时遇到的问题以及描述不明确的地方进行补充和说明 一.首先需要准备以下4个文件 nginx-1.12.0.tar.gz ...
- Hadoop入门学习路线
走上大数据的自学之路....,Hadoop是走上大数据开发学习之路的第一个门槛. Hadoop,是Apache的一个开源项目,开发人员可以在不了解分布式底层细节,开发分布式程序,充分利用集群进行高速运 ...
- webpack4的react打包错误
因为之前一直用的是脚手架创建项目,第一次自己学习创建webpack打包.loader我是复制别人的. module: { loaders: [ { test: /\.js?$/, exclude: / ...
- 使用maven下载cdh版本的大数据jar包
在pom文件中添加 cloudera 配置文件 <repositories> <repository> <id>cloudera</id> <ur ...