FileOutputStream

  1. 创建字节输出流对象FileOutputStream fl =new FileOutputStream()
  • 传入的参数可以是字符串路径或者File对象(实际上如果传入字符串也会在内部创建File对象)
  • 如果文件不存在会在创建一个文件,但是必须保证其父级路径是存在的,这个和File是相似的
  • 如果文件存在,则会清空文件,你可以选择传入第二个参数(boolean),让对象是可以续写的
  1. 写数据fl.write(92)
  • 写入整数,显示对应ascii码值
  • 如果想一口气将字符写入文件:
String str="hello World!"
byte byte1[]=str.getBytes();
fl.write(byte1);
  • 可以写入byte数组,并给出起始位置和总长度(可以不给)
  • 如果想让数据换行可以传入:
String str="\n"
byte byte1[]=str.getBytes();
fl.write(byte1);
  1. 释放资源
  • 使用完都要进行释放,相当于解除对文件的占用

FileinputStream

  1. 创建字节输入对象FileInputStream fl =new FileInputStream()
  • 如果文件不存在,直接报错
  1. 读取数据fl.read()
  • 读取字节数据,将数据进行返回,且读取一次数据,就移动到下一个
  • 读到文件末尾方法返回-1
  1. 释放资源

练习:复制粘贴,并显示花费时长(毫秒)

package Java_test;

import java.io.*;

public class Test {
public static void main(String[] args) throws IOException{
File fl =new File(".\\5.jpg");
FileInputStream infile = new FileInputStream("C:\\Users\\Lenovo\\Pictures\\5665.jpg");
FileOutputStream outfile = new FileOutputStream(fl);
int b=0;
long start = System.currentTimeMillis();
while ((b = infile.read()) != -1) {
outfile.write(b);
}
System.out.println("复制粘贴完成");
long end = System.currentTimeMillis();
System.out.println("总共花费时长:" + (end - start) + " 毫秒");
outfile.close();
infile.close();
}
}

以上练习可以看出,一个字节一个字节进行读取速度会非常慢,为了更快的进行数据传输我们可以用int len = outfile.read(bytes)其中,bytes是字节型字符串,这行代码会读取文件中的数据,并尽可能的填满数组,读取的数据会从头对数组进行覆盖,如果覆盖不完全会使后面出现多余数据,其中数组长度最好是1024的整数倍

所以,我们可以利用他的返回值,len这个指的是读取数据的长度,System.out.println(new String(bytes,0,len));这个String是将从0开始len长度的数据转成字符串,并进行输出

File与IO流之字节流的更多相关文章

  1. JavaSE学习笔记(14)---File类和IO流(字节流和字符流)

    JavaSE学习笔记(14)---File类和IO流(字节流和字符流) File类 概述 java.io.File 类是文件和目录路径名的抽象表示,主要用于文件和目录的创建.查找和删除等操作. 构造方 ...

  2. java io流(字节流)复制文件

    java io流(字节流) 复制文件 //复制文件 //使用字节流 //复制文本文件用字符流,复制其它格式文件用字节流 import java.io.*; public class Index{ pu ...

  3. IO流(字节流复制)01

    package ioDemo; import java.io.*; /** * IO流(字节流复制) * Created by lcj on 2017/11/2. */ public class bu ...

  4. 12.19 file 与io流

    12.19 file与io流 File 1. 新建文件或者文件夹 新建文件 File F = new File(pathname:"路径+文件名");Boolean flag = ...

  5. 【Java IO流】字节流和字符流详解

    字节流和字符流 对于文件必然有读和写的操作,读和写就对应了输入和输出流,流又分成字节和字符流. 1.从对文件的操作来讲,有读和写的操作——也就是输入和输出. 2.从流的流向来讲,有输入和输出之分. 3 ...

  6. JavaSE(十二)之IO流的字节流(一)

    前面我们学习的了多线程,今天开始要学习IO流了,java中IO流的知识非常重要.但是其实并不难,因为他们都有固定的套路. 一.流的概念     流是个抽象的概念,是对输入输出设备的抽象,Java程序中 ...

  7. Java基础:IO流之字节流和字符流

    1. 流的概念 流(stream)的概念源于UNIX中管道(pipe)的概念.在UNIX中,管道是一条不间断的字节流,用来实现程序或进程间的通信,或读写外围设备.外部文件等. 一个流,必有源端和目的端 ...

  8. IO流之字节流

    IO流分类 按照数据流向 输入流:从外界(键盘.网络.文件…)读取数据到内存 输出流:用于将程序中的数据写出到外界(显示器.文件…) 数据源 目的地 交通工具 按照数据类型 字节流:主要用来处理字节或 ...

  9. java基础10(IO流)-字节流

    IO流 输入与输出[参照物是程序] 如果从键盘.文件.网络甚至是另一个进程(程序或系统)将数据读入到程序或系统中,称为输入 如果是将程序或系统中的数据写到屏幕.硬件上的文件.网络上的另一端或者是一个进 ...

  10. IO流总结---- 字节流 ,字符流, 序列化 ,数据操作流,打印流 , Properties 集合

    笔记内容: 什么是流 字节流 字符流 序列化 数据操作流(操作基本数据类型的流)DataInputStream 打印流 Properties 集合 什么是流: 流是个抽象的概念,是对输入输出设备的抽象 ...

随机推荐

  1. Socket通信-Linux系统中C语言实现TCP/UDP图片和文件传输

    TCP实现 传输控制协议(TCP,Transmission Control Protocol) 是为了在不可靠的互联网络上提供可靠的端到端字节流而专门设计的一个传输协议.TCP是因特网中的传输层协议, ...

  2. AI技术革命,工作效率10个最佳AI工具

    AI技术革命,工作效率10个最佳AI工具 目       录 1.      Vidwud AI PowerPoint生成器... 4 2.      Vidnoz AI音乐视频生成器... 5 3. ...

  3. 【问题】抓取微信公众号文章 特殊字符()问题

    最初对抓取的文章处理使用正则表达式统一处理,代码如下: Regex regex_p = new Regex(@"<p>\s*</p>", RegexOpti ...

  4. AI 大模型:现状、挑战与未来多维度发展趋势

    在科技浪潮的推动下,以 Deepseek 为代表的 AI 大模型正以颠覆性力量重塑产业格局.从金融风控到工业质检,从智慧医疗到智能教育,这些轻量化的 AI 工具不仅打破了传统工作模式的桎梏,更构建起一 ...

  5. Netty基础—6.Netty实现RPC服务

    大纲 1.RPC的相关概念 2.RPC服务调用端动态代理实现 3.Netty客户端之RPC远程调用过程分析 4.RPC网络通信中的编码解码器 5.Netty服务端之RPC服务提供端的处理 6.RPC服 ...

  6. gorm中使用乐观锁

    乐观锁简介 乐观锁(又称乐观并发控制)是一种常见的数据库并发控制策略. 乐观并发控制多数用于数据竞争(data race)不大.冲突较少的环境中,这种环境中,偶尔回滚事务的成本会低于读取数据时锁定数据 ...

  7. 四大AI编程工具组合测评

     在当今数字化浪潮中,AI 编程工具如雨后春笋般涌现,极大地提升了编程效率与体验.本文将详细剖析四类 AI 编程工具组合,从开发工具.大模型.插件搭配,到编程能力.费用体系及综合评价,为开发者提供全面 ...

  8. 项目管理协作工具对比:PingCode vs Leangoo

    多语言适配能力 在全球化协作场景下,多语言支持成为跨国团队的硬性指标.PingCode目前仅支持中文界面,对于涉及多国语言协作的团队存在使用局限.对比Leangoo提供中英文双语界面切换功能,可满足基 ...

  9. nacos(八): sentinel——基本使用

    一.概要 在微服务的架构中,流控是一个重要的任务.sentinel是阿里开源的流量治理组件,针对访问的"资源"或服务路径进行流控,内置了限流.熔断及系统负载保护等功能. senti ...

  10. 面试题-Storm框架

    前言 Storm框架在实际项目中已经平稳运行快一年了,也很好的支撑了海量读写器的数据处理需求,不过和RabbitMQ一样,为了项目进度,实际工作中只能尽快的调研,关注一些关键点,其他的细节就只能放一放 ...