javaIO

JavaIO

节点流和处理流分类

按节点流和处理流不同的功能分类:

  1. 节点流:主要是涉及对数据的读写
  2. 处理流:是对一个已存在的流的连接和封装,通过所封装的流的功能调用实现数据读写。如BufferedReader处理流的构造方法总是要带一个其他的流对象做参数。一个流对象经过其他流的多次包装,称为流的链接

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZfA1nx8U-1583143847959)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20200302175118654.png)]

还有打印流:PrintStream``PrintWriter

对象序列化反序列化:ObjectInputStreamObjectOutputStream

字节和字符的不同:

  • 字节是以一个字节为单位运输(单个字节)
  • 字符是以多个字节为单位运输(一个字符,不同编码对应不同的字节)
根据字节流和字符流分类:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-h5zB2JKN-1583143847961)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20200302152313022.png)]

磁盘操作

递归输出一个目录下的所有文件:

public static void listAllFile(File file) {
    if(file == null || !file.exists())return ;
    if(file.isDirectory()) {
        for(File f : file.listFiles()) {
            if(f.isFile())System.out.println(f.getName());
            else listAllFile(f);
        }
    }
}

单个文件的拷贝:

public static boolean copy(String srcFile,String desFile) throws Exception {

    FileInputStream input = new FileInputStream(srcFile);
    FileOutputStream output = new FileOutputStream(desFile);

    byte[] buffer = new byte[20*1024];
    int cnt;
    while((cnt = input.read(buffer, 0, buffer.length))!= -1) {
        output.write(buffer,0,cnt);
    }
    input.close();
    output.close();
    return true;
}

整个目录的拷贝:

File srcf = new File(srcFile); //准备拷贝的目录
File desf = new File(desFile);// 放到的地址

Main.copyDir(srcf, desf,srcf.getPath());  // head: 要替换掉的地址
public static void copyDir(File srcf,File desf,String head) throws Exception {
    if(srcf.isDirectory()) {
        for(File s : srcf.listFiles()) {
            copyDir(s,desf,head);
        }
    }
    else {
        String src = srcf.getPath();
        System.out.println(src);
        String des = desf.getPath() + src.replace(head, "");
        System.out.println(des);
        copy(src,des);
    }
}

**编码和解码:**编码就是把字符转换为字节,而解码是把字节重新组合成字符。

序列化Serializable

序列化就是将一个对象转换成字节序列,方便存储和传输。

  • 序列化:ObjectOutputStream.writeObject()
  • 反序列化:ObjectInputStream.readObject()

不会对静态变量进行序列化,因为序列化只是保存对象的状态,静态变量属于类的状态。

NOI

提供了高速的、面向块的 I/O。

NIOIO的区别:

  • I/O以流的方式处理数据,而NIO以块的方式处理数据
  • I/O一次以一个字节为单位,NIO以一个块为单位,NIO速度更快。
  • NIO 是非阻塞的;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值