java常用字节流

简介: 常用的字节流有FileInputStream和FileOutputStream、BufferedInputStream和BufferedOutputStream、DataInputStream和DataOutputStream。FileInputStream和FileOutputStream是基础的字节输入和输出流,通常在创建缓冲流时需要使用到,也可以用来做文件复

常用的字节流有FileInputStream和FileOutputStream、BufferedInputStream和BufferedOutputStream、DataInputStream和DataOutputStream。

FileInputStream和FileOutputStream是基础的字节输入和输出流,通常在创建缓冲流时需要使用到,也可以用来做文件复制的功能。

 * fileInputStream和fileOutputStream字节输入输出流实现文件的复制
     *
     * @author:tuzongxun
     * @Title: fileInAndOuTest
     * @param
     * @return void
     * @date Jul 20, 2016 10:21:41 AM
     * @throws FileNotFoundException
     */
    public static void fileInAndOuTest() throws IOException {
        File file = new File("C:\\Users\\tuzongxun123\\Desktop\\ioTest1.txt");
        // 创建一个fileInputStream对象
        FileInputStream fileInputStream = new FileInputStream(file);
        FileOutputStream fileOutputStream = new FileOutputStream(new File("C:\\Users\\tuzongxun123\\Desktop\\ioTest.txt"));
        // 获取文件中字符的长度
        int leng = fileInputStream.available();
        System.out.println(leng);
        for (int i = 0; i < leng; i++) {
            // 读取每个字节
            int in = fileInputStream.read();
            System.out.print(in);
            // 把读取的字节写入到另一个文件
            fileOutputStream.write(in);
        }
        fileInputStream.close();
        // 使文件立即写入到磁盘
        fileOutputStream.flush();
        fileOutputStream.close();
    }

BufferedInputStream和BufferedOutputStream是缓冲字节输入输出流,相对于基础的字节流有更高的效率,而效率更高的原理在于用空间换取时间。
也就是说使用缓冲流的时候,会先把一定的数据放到缓冲区,也就是内存中,然后read的时候直接从缓冲区读取,这样就减少了读写磁盘文件的次数,从而减少读写时间。

/**
     * BufferedInputStream和BufferedOutputStream缓冲流复制文件
     * 
     * @author:tuzongxun
     * @Title: bufferedTest
     * @param @throws IOException
     * @return void
     * @date Jul 21, 2016 9:05:57 AM
     * @throws
     */
    public static void bufferedTest() throws IOException {
        File file = new File("C:\\Users\\tuzongxun123\\Desktop\\ioTest1.txt");
        File file1 = new File("C:\\Users\\tuzongxun123\\Desktop\\ioTest2.txt");
        // 缓冲输入流对象,bis和bos作为缓冲区,
        BufferedInputStream bis = new BufferedInputStream(new FileInputStream(file));
        // 缓冲输出流对象
        BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(file1));
        //声明缓冲区大小
        byte[] byte1 = new byte[1024];
        while (bis.read(byte1) != -1) {
            bos.write(byte1);
        } ;
        // 将缓冲区中的数据全部写出
        bos.flush();
        bis.close();
        bos.close();
    }

DataInputStream和DataOutputStream被称为数据输入输出流,他们因为自己的特性而常被用于网络传输,它可以保证“无论数据来自何种机器,只要使用一个DataInputStream收取这些数据,就可用本机正确的格式保存它们.“
不过现在使用spring做文件上传和下载时我自己使用的是MultipartFile,所以也就没有做DataInputStream和DataOutputStream的例子。
MultipartFile上传文件的例子可以参考:
使用springMVC实现文件上传和下载之环境配置与上传

目录
相关文章
|
机器学习/深度学习 人工智能 自然语言处理
【AI系统】大模型的到来
大模型的兴起,让系统工程师能在前所未有的集群规模上解决复杂工程问题,显著降低成本和时间。本文探讨了大模型的发展历程、技术架构、支持模态及应用领域,特别分析了AI系统与AI基础设施的区别及其对大模型的影响。随着大模型进入爆发期,AI系统的重要性日益凸显,不仅影响着算法的选择与发展,也成为推动大模型研究与应用的关键力量。
955 0
|
12月前
|
设计模式 消息中间件 供应链
前端必须掌握的设计模式——发布订阅模式
发布订阅模式(Publish-Subscribe Pattern)是一种设计模式,类似于观察者模式,但通过引入第三方中介实现发布者和订阅者的解耦。发布者不再直接通知订阅者,而是将消息发送给中介,由中介负责分发给订阅者。这种方式提高了异步支持和安全性,适合复杂、高并发场景,如消息队列和流处理系统。代码实现中,通过定义发布者、订阅者和中介接口,确保消息的正确传递。此模式在前端开发中广泛应用,例如Vue的数据双向绑定。
|
监控 安全 数据安全/隐私保护
什么是OTA升级模式?
【7月更文挑战第20天】什么是OTA升级模式?
2111 8
|
运维 Cloud Native 持续交付
云原生技术:现代应用架构的未来
在当今数字化转型的浪潮中,云原生技术成为企业加速创新和扩展业务的核心。本文探讨了云原生技术的定义、优势及其在现代应用架构中的关键作用。通过深入分析容器化、微服务架构和持续交付等关键技术,揭示了云原生技术如何为企业提供灵活性、可靠性和可扩展性,从而实现更高效的软件开发和部署流程。
190 27
|
测试技术
【测试】优化软件测试:有效测试用例设计的关键
【测试】优化软件测试:有效测试用例设计的关键
|
消息中间件 存储 监控
【ZeroMQ的SUB视角】深入探讨订阅者模式、C++编程实践与底层机制
【ZeroMQ的SUB视角】深入探讨订阅者模式、C++编程实践与底层机制
1534 1
|
消息中间件 Java Kafka
kafka log4j日志级别修改,一天生成一个日志文件
kafka log4j日志级别修改,一天生成一个日志文件
|
算法 前端开发
详解双端队列&单调队列
详解双端队列&单调队列
|
存储 分布式计算 监控
HDFS的主要特点是什么?为什么它适合处理大规模数据集?
HDFS的主要特点是什么?为什么它适合处理大规模数据集?
684 0

热门文章

最新文章