节点流——FileInputStream&FileOutputStream
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import org.junit.Test;
/**
*1.流的分类:
* 按照流向的不同分为:输入流 输出流
*按照处理数据单位的不通分为:字节流 字符流(处理的文本文件)
* 按照角色的不通分为 节点流(直接作用于文件的)处理流
*
*1.IO的体系:
* 抽象基类 节点流(文件流) 缓冲流
* InputStream FileInputStream BufferedInputStream
* OutputStream FileOutputStream BufferedOutputStream
* Reader FileReader BufferedReader
* Writer FileWriter BufferedWriter
*/
public class TestFileInputOutStream {
//实现复制的方法,封好的方法
public static void copy(String str,String desc) throws Exception{
File f = new File(str);
FileInputStream fis = new FileInputStream(f);
File out = new File(desc);
FileOutputStream fos = new FileOutputStream(out);
byte[] b= new byte[1024];
int len;
while((len = fis.read(b)) != -1){
fos.write(b, 0, len);
}
}
//实现图片的复制
@Test
public void testImgCopy() throws Exception{
File f = new File("/Users/lixiuming/Desktop/商品详情图片/detail-1.jpg");
FileInputStream fis = new FileInputStream(f);
File out = new File("/Users/lixiuming/Desktop/project/day_15/detail-1.jpg");
FileOutputStream fos = new FileOutputStream(out);
byte[] b= new byte[1024];
int len;
while((len = fis.read(b)) != -1){
fos.write(b, 0, len);
}
}
//从硬盘读取一个文件,并写入另外一个位置,相当于复制
@Test
public void testInputOutputStream() throws Exception{
File in = new File("hello.txt");
FileInputStream fis = new FileInputStream(in);
File out = new File("hello2.txt");
FileOutputStream fos = new FileOutputStream(out);
byte[] b = new byte[1024];
int len;
while((len = fis.read(b)) != -1){
fos.write(b, 0, len);
}
}
@Test
public void testFileOutputStream() throws Exception{
//创建一个File对象,表明要写入的文件位置
//输出的物理文件可以不存在,若不存在,在执行过程中会自动创建,若存在,则将原来的东西覆盖
File file = new File("hello2.txt");
//创建一个文件输出流对象,将File对象作为形参传递给FileOutputStream构造器中
FileOutputStream fos = new FileOutputStream(file);
//写入操作
fos.write(new String("lixiuming lixiuming lixiuming ").getBytes());
//关闭输出流
fos.close();
}
//从硬盘存在的一个文件中,读取其内容到程序中,使用FileInputStream
//要读取的文件一定要存在,否则空指针异常
@Test
public void testFileInputStream1() throws Exception{
//创建一个File类的对象
File file1 = new File("hello.txt");
//创建一个FileInputStream类的对象
FileInputStream fis = new FileInputStream(file1);
//调用FileInputStream方法,实现file1文件的读取
/**
*read()读取文件的一个字节 ,有循环的话,依次指向下一个数据,
*/
// int b = fis.read();
// while(b != -1){
// System.out.print((char)b);
// b = fis.read();
// }
int len;//每次读入到byte中的字节长度
byte[] bb = new byte[1024];//读取到的数据,返回个数(没有数据了就返回-1)
while(( len = fis.read(bb)) != -1){
// for(int i=0;i<len;i++){
// System.out.print((char)bb[i]);
// }
String str = new String(bb, 0, len);
System.out.println(str);
}
//关闭相应的流
fis.close();
}
}
节点流——FileInputStream&FileOutputStream的更多相关文章
- 节点流(文件流) FileInputStream & FileOutputStream & FileReader & FileWriter
节点流(文件流) FileInputStream(字节流)处理视频类的 FileOutputStream(字节流) FileReader(字符流)处理文本文件 ...
- Java API —— IO流( FileInputStream & FileOutputStream & BufferedInputStream & BufferedOutputStream )
1.IO流概述 · IO流用来处理设备之间的数据传输 · 上传文件和下载文件 · Java对数据的操作是通过流的方式 · Java用于操作流的对象都在IO包中 2.IO ...
- 使用文件流与使用缓冲流完成文件的复制操作性能对比,文件流 FileInputStream FileOutputStream 缓冲流: BufferedInputStream BufferedOutputStream
package seday06; import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.IOExc ...
- IO学习二(节点流)
1.流的分类 按照数据流向的不同:输入流和输出流 按照处理数据的单位不同:字节流((非文本文件)视频.音频.图像).字符流(文本文件) 按照角色的不同:节点流和处理流 2.IO体系 抽象基类 节点流 ...
- Java基础知识强化之IO流笔记22:FileInputStream / FileOutputStream 复制文本文件案例1
1. 使用字节流FileInputStream / FileOutputStream 复制文本文件案例: 分析: (1)数据源:从哪里来 a.txt -- 读取数据 -- FileInpu ...
- JAVA里面的IO流(一)分类2(节点流和处理流及构造方法概要)
IO流根据处理对象的不同分为节点流和处理流. 直接对文件进行处理的流为节点流: 对流进行包装从而实现对文件的优化处理的流为处理流. 节点流类型: 可以看出,节点流主要分这几大类: 文件流 文件流构造方 ...
- Java IO 节点流 FileInput/OutputStream
Java IO 节点流 FileInput/OutputStream @author ixenos 节点流之 文件流 文件读写是最常见的I/O操作,通过文件流来连接磁盘文件,读写文件内容 1.文件的读 ...
- Java IO 节点流 ByteArrayInput/OutputStream
Java IO 节点流 ByteArrayInput/OutputStream @author ixenos ByteArrayInputStream 包含一个内部缓冲区(字节数组byte[]),该缓 ...
- Java基础—IO小结(一)概述与节点流
一.File类的使用 由于file类是一个基础类,所以我们从file类开始了解.(SE有完善的中文文档,建议阅读) 构造器: 常用方法:——完整方法请参见API API API!!! File做的是 ...
随机推荐
- Spark运行命令示例
local单机模式:结果xshell可见:./bin/spark-submit --class org.apache.spark.examples.SparkPi --master local[1] ...
- 题解 CF734A 【Anton and Danik】
本蒟蒻闲来无事刷刷水题 话说这道题,看楼下的大佬们基本都是用字符 ( char ) 来做的,那么我来介绍一下C++的优势: string ! string,也就是类型串,是C语言没有的,使用十分方便 ...
- ZJOI2004 午餐
题目传送门 嗯--我承认我看了题解,不过好歹有了点自己的思路,大约蒙出来了\(30\%\)(个人感觉)-- 学会\(DP\),任重而道远啊! Step1.贪心排序 先将每个人按吃饭的快慢排序,然后再进 ...
- basic_double_stream_incorrect
不合理的代码 /* * Copyright 1993-2010 NVIDIA Corporation. All rights reserved. * * NVIDIA Corporation and ...
- Nginx学习记录(一)
1. 什么是nginx Nginx是一款高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器.由俄罗斯的程序设计师Igor Sysoev所开发,官方测试nginx能够支支 ...
- SQL Server中Table字典数据的查询SQL示例代码
SQL Server中Table字典数据的查询SQL示例代码 前言 在数据库系统原理与设计(第3版)教科书中这样写道: 数据库包含4类数据: 1.用户数据 2.元数据 3.索引 4.应用元数据 其中, ...
- css分层,实现遮罩底层弹出新窗口里可以操作,最下层能看到单不能操作
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Java中json前后端日期传递处理
这里推荐2种方式 依赖包 <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifa ...
- mysql 报错 Operand should contain 1 column(s)
报错 Operand should contain 1 column(s) 原因 select 后面加了 () select (x,x,x)
- 安全 - 堡垒机 - Jumpserver
GitHub - jumpserver/Dockerfile: Jumpserver all in one Dockerfile https://github.com/jumpserver/Docke ...