Java基础-20总结,递归,IO流

简介: 你需要的是什么,直接评论留言。 获取更多资源加微信公众号“Java帮帮” (是公众号,不是微信好友哦) 还有“Java帮帮”今日头条号,技术文章与新闻,每日更新,欢迎阅读 学习交流请加Java帮帮交流QQ群553841695 分享是一种美德,分享更快乐! 1:递归(理解) (1)方法定义中调用方法本身的现象 举例:老和尚给小

你需要的是什么,直接评论留言。

获取更多资源加微信公众号“Java帮帮” (是公众号,不是微信好友哦)

还有“Java帮帮”今日头条号,技术文章与新闻,每日更新,欢迎阅读

学习交流请加Java帮帮交流QQ群553841695

分享是一种美德,分享更快乐!


1:递归(理解)

(1)方法定义中调用方法本身的现象

举例:老和尚给小和尚讲故事,我们学编程

(2)递归的注意事项;

A:要有出口,否则就是死递归

B:次数不能过多,否则内存溢出

C:构造方法不能递归使用


package cn.itcast_01;


/*

 * 递归:方法定义中调用方法本身的现象

 * 

 * 方法的嵌套调用,这不是递归。

 * Math.max(Math.max(a,b),c);

 * 

 * public void show(int n) {

 *  if(n <= 0) {

 *  System.exit(0);

 *  }

 *  System.out.println(n);

 *  show(--n);

 * }

 * 

 * 注意事项:

 *  A:递归一定要有出口,否则就是死递归

 *  B:递归的次数不能太多,否则就内存溢出

 *  C:构造方法不能递归使用

 * 

 * 举例:

 *  A:从前有座山,山里有座庙,庙里有个老和尚和小和尚,老和尚在给小和尚讲故事,故事是:

 *  从前有座山,山里有座庙,庙里有个老和尚和小和尚,老和尚在给小和尚讲故事,故事是:

 *  从前有座山,山里有座庙,庙里有个老和尚和小和尚,老和尚在给小和尚讲故事,故事是:

 *  从前有座山,山里有座庙,庙里有个老和尚和小和尚,老和尚在给小和尚讲故事,故事是:

 *  ...

 *  庙挂了,或者山崩了

 *  B:学编程  -- 高薪就业 -- 挣钱 -- 娶媳妇 -- 生娃娃 -- 放羊 -- 挣学费

 *   学编程  -- 高薪就业 -- 挣钱 -- 娶媳妇 -- 生娃娃 -- 放羊 -- 挣学费

 *  学编程  -- 高薪就业 -- 挣钱 -- 娶媳妇 -- 生娃娃 -- 放羊 -- 挣学费

 *  学编程  -- 高薪就业 -- 挣钱 -- 娶媳妇 -- 生娃娃 -- 放羊 -- 挣学费

 *  ...

 *  娶不到媳妇或者生不了娃娃

 */

public class DiGuiDemo {

// public DiGuiDemo() {

// DiGuiDemo();

// }

}




(3)递归的案例:

A:递归求阶乘


package cn.itcast_02;


/*

 * 需求:请用代码实现求5的阶乘。

 * 下面的知识要知道:

 *  5! = 1*2*3*4*5

 *  5! = 5*4!

 * 

 * 有几种方案实现呢?

 *  A:循环实现

 *  B:递归实现

 *  a:做递归要写一个方法

 *  b:出口条件

 *  c:规律

 */

public class DiGuiDemo {

public static void main(String[] args) {

int jc = 1;

for (int x = 2; x <= 5; x++) {

jc *= x;

}

System.out.println("5的阶乘是:" + jc);

System.out.println("5的阶乘是:"+jieCheng(5));

}

/*

 * 做递归要写一个方法:

 *  返回值类型:int

 *  参数列表:int n

 * 出口条件:

 *  if(n == 1) {return 1;}

 * 规律:

 *  if(n != 1) {return n*方法名(n-1);}

 */

public static int jieCheng(int n){

if(n==1){

return 1;

}else {

return n*jieCheng(n-1);

}

}

}



B:兔子发展问题    (斐波那契数列)


package cn.itcast_02;


/*

 * 有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问第二十个月的兔子对数为多少?

 * 分析:我们要想办法找规律

 *  兔子对数

 * 第一个月:  1

 * 第二个月: 1

 * 第三个月: 2

 * 第四个月: 3

 * 第五个月: 5

 * 第六个月: 8

 * ...

 * 

 * 由此可见兔子对象的数据是:

 *  1,1,2,3,5,8...

 * 规则:

 *  A:从第三项开始,每一项是前两项之和

 *  B:而且说明前两项是已知的

 * 

 * 如何实现这个程序呢?

 *  A:数组实现

 *  B:变量的变化实现

 *  C:递归实现

 * 

 * 假如相邻的两个月的兔子对数是a,b

 * 第一个相邻的数据:a=1,b=1

 * 第二个相邻的数据:a=1,b=2

 * 第三个相邻的数据:a=2,b=3

 * 第四个相邻的数据:a=3,b=5

 * 看到了:下一次的a是以前的b,下一次是以前的a+b

 */

public class DiGuiDemo2 {

public static void main(String[] args) {

// 定义一个数组

int[] arr = new int[20];

arr[0] = 1;

arr[1] = 1;

// arr[2] = arr[0] + arr[1];

// arr[3] = arr[1] + arr[2];

// ...

for (int x = 2; x < arr.length; x++) {

arr[x] = arr[x - 2] + arr[x - 1];

}

System.out.println(arr[19]);// 6765

System.out.println("----------------");


int a = 1;

int b = 1;

for (int x = 0; x < 18; x++) {

// 临时变量存储上一次的a

int temp = a;

a = b;

b = temp + b;

}

System.out.println(b);

System.out.println("----------------");


System.out.println(fib(20));

}


/*

 * 方法: 返回值类型:int 参数列表:int n 出口条件: 第一个月是1,第二个月是1 规律: 从第三个月开始,每一个月是前两个月之和

 */

public static int fib(int n) {

if (n == 1 || n == 2) {

return 1;

} else {

return fib(n - 1) + fib(n - 2);

}

}

}


C:递归输出指定目录下所有指定后缀名的文件绝对路径


package cn.itcast_03;


import java.io.File;


/*

 * 需求:请大家把E:\JavaSE目录下所有的java结尾的文件的绝对路径给输出在控制台。

 * 

 * 分析:

 *  A:封装目录

 *  B:获取该目录下所有的文件或者文件夹的File数组

 *  C:遍历该File数组,得到每一个File对象

 *  D:判断该File对象是否是文件夹

 *  是:回到B

 *  否:继续判断是否以.java结尾

 *  是:就输出该文件的绝对路径

 *  否:不搭理它

 */

public class FilePathDemo {

public static void main(String[] args) {

// 封装目录

File srcFolder = new File("E:\\JavaSE");


// 递归功能实现

getAllJavaFilePaths(srcFolder);

}


private static void getAllJavaFilePaths(File srcFolder) {

// 获取该目录下所有的文件或者文件夹的File数组

File[] fileArray = srcFolder.listFiles();


// 遍历该File数组,得到每一个File对象

for (File file : fileArray) {

// 判断该File对象是否是文件夹

if (file.isDirectory()) {

getAllJavaFilePaths(file);

} else {

// 继续判断是否以.java结尾

if (file.getName().endsWith(".java")) {

// 就输出该文件的绝对路径

System.out.println(file.getAbsolutePath());

}

}

}

}

}



D:递归删除带内容的目录(小心使用)


package cn.itcast_03;


import java.io.File;


/*

 * 需求:递归删除带内容的目录

 * 

 * 目录我已经给定:demo

 * 

 * 分析:

 *  A:封装目录

 *  B:获取该目录下的所有文件或者文件夹的File数组

 *  C:遍历该File数组,得到每一个File对象

 *  D:判断该File对象是否是文件夹

 *  是:回到B

 *  否:就删除

 */

public class FileDeleteDemo {

public static void main(String[] args) {

// 封装目录

File srcFolder = new File("demo");

// 递归实现

deleteFolder(srcFolder);

}


private static void deleteFolder(File srcFolder) {

// 获取该目录下的所有文件或者文件夹的File数组

File[] fileArray = srcFolder.listFiles();


if (fileArray != null) {

// 遍历该File数组,得到每一个File对象

for (File file : fileArray) {

// 判断该File对象是否是文件夹

if (file.isDirectory()) {

deleteFolder(file);

} else {

System.out.println(file.getName() + "---" + file.delete());

}

}


System.out

.println(srcFolder.getName() + "---" + srcFolder.delete());

}

}

}




2:IO流(掌握)

(1)IO用于在设备间进行数据传输的操作

(2)分类:

A:流向

输入流 读取数据

输出流 写出数据

B:数据类型

字节流

字节输入流

字节输出流

字符流

字符输入流

字符输出流

注意:

a:如果我们没有明确说明按照什么分,默认按照数据类型分。

b:除非文件用windows自带的记事本打开我们能够读懂,才采用字符流,否则建议使用字节流。

(3)FileOutputStream写出数据

A:操作步骤

a:创建字节输出流对象

b:调用write()方法

c:释放资源

B:代码体现:

FileOutputStream fos = new FileOutputStream("fos.txt");

fos.write("hello".getBytes());

fos.close();

C:要注意的问题?

a:创建字节输出流对象做了几件事情?


b:为什么要close()?


package cn.itcast_01;


import java.io.File;

import java.io.FileNotFoundException;

import java.io.FileOutputStream;

import java.io.IOException;


/*

 * IO流的分类:

 *  流向:

 *  输入流 读取数据

 *  输出流 写出数据

 *  数据类型:

 *  字节流

 *  字节输入流 读取数据 InputStream

 *  字节输出流 写出数据 OutputStream

 *  字符流

 *  字符输入流 读取数据 Reader

 *  字符输出流 写出数据 Writer

 * 

 *  注意:一般我们在探讨IO流的时候,如果没有明确说明按哪种分类来说,默认情况下是按照数据类型来分的。

 * 

 * 需求:我要往一个文本文件中输入一句话:"hello,io"

 * 

 * 分析:

 *  A:这个操作最好是采用字符流来做,但是呢,字符流是在字节流之后才出现的,所以,今天我先讲解字节流如何操作。

 *  B:由于我是要往文件中写一句话,所以我们要采用字节输出流。

 * 

 * 通过上面的分析后我们知道要使用:OutputStream

 * 但是通过查看API,我们发现该流对象是一个抽象类,不能实例化。

 * 所以,我们要找一个具体的子类。

 * 而我们要找的子类是什么名字的呢?这个时候,很简单,我们回想一下,我们是不是要往文件中写东西。

 * 文件是哪个单词:File

 * 然后用的是字节输出流,联起来就是:FileOutputStream

 * 注意:每种基类的子类都是以父类名作为后缀名。

 *  XxxOutputStream

 *  XxxInputStream

 *  XxxReader

 *  XxxWriter

 * 查看FileOutputStream的构造方法:

 *  FileOutputStream(File file) 

 * FileOutputStream(String name)

 *

 * 字节输出流操作步骤:

 *  A:创建字节输出流对象

 *  B:写数据

 *  C:释放资源

 */

public class FileOutputStreamDemo {

public static void main(String[] args) throws IOException {

// 创建字节输出流对象

// FileOutputStream(File file)

// File file = new File("fos.txt");

// FileOutputStream fos = new FileOutputStream(file);

// FileOutputStream(String name)

FileOutputStream fos = new FileOutputStream("fos.txt");

/*

 * 创建字节输出流对象了做了几件事情:

 * A:调用系统功能去创建文件

 * B:创建fos对象

 * C:把fos对象指向这个文件

 */

//写数据

fos.write("hello,IO".getBytes());

fos.write("java".getBytes());

//释放资源

//关闭此文件输出流并释放与此流有关的所有系统资源。

fos.close();

/*

 * 为什么一定要close()呢?

 * A:让流对象变成垃圾,这样就可以被垃圾回收器回收了

 * B:通知系统去释放跟该文件相关的资源

 */

//java.io.IOException: Stream Closed

//fos.write("java".getBytes());

}

}


c:如何实现数据的换行?

d:如何实现数据的追加写入?


package cn.itcast_01;


import java.io.FileOutputStream;

import java.io.IOException;


/*

 * 如何实现数据的换行?

 *  为什么现在没有换行呢?因为你值写了字节数据,并没有写入换行符号。

 *  如何实现呢?写入换行符号即可呗。

 *  刚才我们看到了有写文本文件打开是可以的,通过windows自带的那个不行,为什么呢?

 *  因为不同的系统针对不同的换行符号识别是不一样的?

 *  windows:\r\n

 *  linux:\n

 *  Mac:\r

 *  而一些常见的个高级记事本,是可以识别任意换行符号的。

 * 

 * 如何实现数据的追加写入?

 *  用构造方法带第二个参数是true的情况即可

 */

public class FileOutputStreamDemo3 {

public static void main(String[] args) throws IOException {

// 创建字节输出流对象

// FileOutputStream fos = new FileOutputStream("fos3.txt");

// 创建一个向具有指定 name 的文件中写入数据的输出文件流。如果第二个参数为 true,则将字节写入文件末尾处,而不是写入文件开始处。

FileOutputStream fos = new FileOutputStream("fos3.txt", true);


// 写数据

for (int x = 0; x < 10; x++) {

fos.write(("hello" + x).getBytes());

fos.write("\r\n".getBytes());

}


// 释放资源

fos.close();

}

}

e:异常处理的字节输出流操作



package cn.itcast_01;


import java.io.FileNotFoundException;

import java.io.FileOutputStream;

import java.io.IOException;


/*

 * 加入异常处理的字节输出流操作

 */

public class FileOutputStreamDemo4 {

public static void main(String[] args) {

// 分开做异常处理

// FileOutputStream fos = null;

// try {

// fos = new FileOutputStream("fos4.txt");

// } catch (FileNotFoundException e) {

// e.printStackTrace();

// }

//

// try {

// fos.write("java".getBytes());

// } catch (IOException e) {

// e.printStackTrace();

// }

//

// try {

// fos.close();

// } catch (IOException e) {

// e.printStackTrace();

// }


// 一起做异常处理

// try {

// FileOutputStream fos = new FileOutputStream("fos4.txt");

// fos.write("java".getBytes());

// fos.close();

// } catch (FileNotFoundException e) {

// e.printStackTrace();

// } catch (IOException e) {

// e.printStackTrace();

// }


// 改进版

// 为了在finally里面能够看到该对象就必须定义到外面,为了访问不出问题,还必须给初始化值

FileOutputStream fos = null;

try {

// fos = new FileOutputStream("z:\\fos4.txt");

fos = new FileOutputStream("fos4.txt");

fos.write("java".getBytes());

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

} finally {

// 如果fos不是null,才需要close()

if (fos != null) {

// 为了保证close()一定会执行,就放到这里了

try {

fos.close();

} catch (IOException e) {

e.printStackTrace();

}

}

}

}

}


(4)FileInputStream读取数据

A:操作步骤

a:创建字节输入流对象

b:调用read()方法

c:释放资源

B:代码体现:

FileInputStream fis = new FileInputStream("fos.txt");

//方式1

int by = 0;

while((by=fis.read())!=-1) {

System.out.print((char)by);

}

//方式2

byte[] bys = new byte[1024];

int len = 0;

while((len=fis.read(bys))!=-1) {

System.out.print(new String(bys,0,len));

}

fis.close();



(5)案例:2种实现


A:int read():一次读取一个字节


package cn.itcast_02;


import java.io.FileInputStream;

import java.io.IOException;


/*

 * 字节输入流操作步骤:

 * A:创建字节输入流对象

 * B:调用read()方法读取数据,并把数据显示在控制台

 * C:释放资源

 * 

 * 读取数据的方式:

 * A:int read():一次读取一个字节

 * B:int read(byte[] b):一次读取一个字节数组

 */

public class FileInputStreamDemo {

public static void main(String[] args) throws IOException {

// FileInputStream(String name)

// FileInputStream fis = new FileInputStream("fis.txt");

FileInputStream fis = new FileInputStream("FileOutputStreamDemo.java");


// // 调用read()方法读取数据,并把数据显示在控制台

// // 第一次读取

// int by = fis.read();

// System.out.println(by);

// System.out.println((char) by);

//

// // 第二次读取

// by = fis.read();

// System.out.println(by);

// System.out.println((char) by);

//

// // 第三次读取

// by = fis.read();

// System.out.println(by);

// System.out.println((char) by);

// // 我们发现代码的重复度很高,所以我们要用循环改进

// // 而用循环,最麻烦的事情是如何控制循环判断条件呢?

// // 第四次读取

// by = fis.read();

// System.out.println(by);

// // 第五次读取

// by = fis.read();

// System.out.println(by);

// //通过测试,我们知道如果你读取的数据是-1,就说明已经读取到文件的末尾了


// 用循环改进

// int by = fis.read();

// while (by != -1) {

// System.out.print((char) by);

// by = fis.read();

// }


// 最终版代码

int by = 0;

// 读取,赋值,判断

while ((by = fis.read()) != -1) {

System.out.print((char) by);

}


// 释放资源

fis.close();

}

}


B:int read(byte[] b):一次读取一个字节数组


package cn.itcast_02;


import java.io.FileInputStream;

import java.io.IOException;


/*

 * 一次读取一个字节数组:int read(byte[] b)

 * 返回值其实是实际读取的字节个数。

 */

public class FileInputStreamDemo2 {

public static void main(String[] args) throws IOException {

// 创建字节输入流对象

// FileInputStream fis = new FileInputStream("fis2.txt");

FileInputStream fis = new FileInputStream("FileOutputStreamDemo.java");


// 读取数据

// 定义一个字节数组

// 第一次读取

// byte[] bys = new byte[5];

// int len = fis.read(bys);

// // System.out.println(len);

// // System.out.println(new String(bys));

// // System.out.println(new String(bys, 0, len));

// System.out.print(new String(bys, 0, len));

//

// // 第二次读取

// len = fis.read(bys);

// // System.out.println(len);

// // System.out.println(new String(bys));

// // System.out.println(new String(bys, 0, len));

// System.out.print(new String(bys, 0, len));

//

// // 第三次读取

// len = fis.read(bys);

// // System.out.println(len);

// // System.out.println(new String(bys));

// // System.out.println(new String(bys, 0, len));

// System.out.print(new String(bys, 0, len));

//

// // 第四次读取

// len = fis.read(bys);

// // System.out.println(len);

// // System.out.println(new String(bys, 0, len));

// System.out.print(new String(bys, 0, len));

// // 代码重复了,用循环改进

// // 但是,我不知道结束条件

// // len = fis.read(bys);

// // System.out.println(len);

// // len = fis.read(bys);

// // System.out.println(len);

// // 如果读取到的实际长度是-1,就说明没有数据了


// byte[] bys = new byte[115]; // 0

// int len = 0;

// while ((len = fis.read(bys)) != -1) {

// System.out.print(new String(bys, 0, len));

// // System.out.print(new String(bys)); //千万要带上len的使用

// }


// 最终版代码

// 数组的长度一般是1024或者1024的整数倍

byte[] bys = new byte[1024];

int len = 0;

while ((len = fis.read(bys)) != -1) {

System.out.print(new String(bys, 0, len));

}


// 释放资源

fis.close();

}

}




A:复制文本文件


package cn.itcast_03;


import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;


/*

 * 复制文本文件。

 * 

 * 数据源:从哪里来

 * a.txt -- 读取数据 -- FileInputStream

 * 

 * 目的地:到哪里去

 * b.txt -- 写数据 -- FileOutputStream

 * 

 * java.io.FileNotFoundException: a.txt (系统找不到指定的文件。)

 * 

 * 这一次复制中文没有出现任何问题,为什么呢?

 * 上一次我们出现问题的原因在于我们每次获取到一个字节数据,就把该字节数据转换为了字符数据,然后输出到控制台。

 * 而这一次呢?确实通过IO流读取数据,写到文本文件,你读取一个字节,我就写入一个字节,你没有做任何的转换。

 * 它会自己做转换。

 */

public class CopyFileDemo {

public static void main(String[] args) throws IOException {

// 封装数据源

FileInputStream fis = new FileInputStream("a.txt");

// 封装目的地

FileOutputStream fos = new FileOutputStream("b.txt");


int by = 0;

while ((by = fis.read()) != -1) {

fos.write(by);

}


// 释放资源(先关谁都行)

fos.close();

fis.close();

}

}


B:把c盘下的a.txt的内容复制到d盘下的b.txt中


package cn.itcast_03;


import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;


/*

 * 需求:把c盘下的a.txt的内容复制到d盘下的b.txt中

 * 

 * 数据源:

 *  c:\\a.txt -- 读取数据-- FileInputStream

 * 目的地:

 *  d:\\b.txt -- 写出数据 -- FileOutputStream

 */

public class CopyFileDemo2 {

public static void main(String[] args) throws IOException {

// 封装数据源

FileInputStream fis = new FileInputStream("c:\\a.txt");

// 封装目的地

FileOutputStream fos = new FileOutputStream("d:\\b.txt");


// 复制数据

int by = 0;

while ((by = fis.read()) != -1) {

fos.write(by);

}


// 释放资源

fos.close();

fis.close();

}

}


c:复制图片


package cn.itcast_03;


import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;


/*

 * 需求:把e:\\林青霞.jpg内容复制到当前项目目录下的mn.jpg中

 * 

 * 数据源:

 *  e:\\林青霞.jpg --读取数据--FileInputStream

 * 目的地:

 *  mn.jpg--写出数据--FileOutputStream

 */

public class CopyImageDemo {

public static void main(String[] args) throws IOException {

// 封装数据源

FileInputStream fis = new FileInputStream("e:\\林青霞.jpg");

// 封装目的地

FileOutputStream fos = new FileOutputStream("mn.jpg");


// 复制数据

int by = 0;

while ((by = fis.read()) != -1) {

fos.write(by);

}


// 释放资源

fos.close();

fis.close();

}

}



d:复制视频


package cn.itcast_03;


import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;


/*

 * 需求:把e:\\哥有老婆.mp4复制到当前项目目录下的copy.mp4中

 * 

 * 数据源:

 *  e:\\哥有老婆.mp4--读取数据--FileInputStream

 * 目的地:

 *  copy.mp4--写出数据--FileOutputStream

 */

public class CopyMp4Demo {

public static void main(String[] args) throws IOException {

// 封装数据源

FileInputStream fis = new FileInputStream("e:\\哥有老婆.mp4");

// 封装目的地

FileOutputStream fos = new FileOutputStream("copy.mp4");


// 复制数据

int by = 0;

while ((by = fis.read()) != -1) {

fos.write(by);

}


// 释放资源

fos.close();

fis.close();

}

}



e:计算机是如何识别什么时候该把两个字节转换为一个中文呢?


package cn.itcast_03;


import java.util.Arrays;


/*

 * 计算机是如何识别什么时候该把两个字节转换为一个中文呢?

 * 在计算机中中文的存储分两个字节:

 *  第一个字节肯定是负数。

 *  第二个字节常见的是负数,可能有正数。但是没影响。

 */

public class StringDemo {

public static void main(String[] args) {

// String s = "abcde";

// // [97, 98, 99, 100, 101]


String s = "我爱你中国";

// [-50, -46, -80, -82, -60, -29, -42, -48, -71, -6]


byte[] bys = s.getBytes();

System.out.println(Arrays.toString(bys));

}

}


(6)字节缓冲区流

A:BufferedOutputStream


package cn.itcast_05;


import java.io.BufferedOutputStream;

import java.io.FileOutputStream;

import java.io.IOException;


/*

 * 通过定义数组的方式确实比以前一次读取一个字节的方式快很多,所以,看来有一个缓冲区还是非常好的。

 * 既然是这样的话,那么,java开始在设计的时候,它也考虑到了这个问题,就专门提供了带缓冲区的字节类。

 * 这种类被称为:缓冲区类(高效类)

 * 写数据:BufferedOutputStream

 * 读数据:BufferedInputStream

 * 

 * 构造方法可以指定缓冲区的大小,但是我们一般用不上,因为默认缓冲区大小就足够了。

 * 

 * 为什么不传递一个具体的文件或者文件路径,而是传递一个OutputStream对象呢?

 * 原因很简单,字节缓冲区流仅仅提供缓冲区,为高效而设计的。但是呢,真正的读写操作还得靠基本的流对象实现。

 */

public class BufferedOutputStreamDemo {

public static void main(String[] args) throws IOException {

// BufferedOutputStream(OutputStream out)

// FileOutputStream fos = new FileOutputStream("bos.txt");

// BufferedOutputStream bos = new BufferedOutputStream(fos);

// 简单写法

BufferedOutputStream bos = new BufferedOutputStream(

new FileOutputStream("bos.txt"));


// 写数据

bos.write("hello".getBytes());


// 释放资源

bos.close();

}

}


B:BufferedInputStream


package cn.itcast_05;


import java.io.BufferedInputStream;

import java.io.FileInputStream;

import java.io.IOException;


/*

 * 注意:虽然我们有两种方式可以读取,但是,请注意,这两种方式针对同一个对象在一个代码中只能使用一个。

 */

public class BufferedInputStreamDemo {

public static void main(String[] args) throws IOException {

// BufferedInputStream(InputStream in)

BufferedInputStream bis = new BufferedInputStream(new FileInputStream(

"bos.txt"));


// 读取数据

// int by = 0;

// while ((by = bis.read()) != -1) {

// System.out.print((char) by);

// }

// System.out.println("---------");


byte[] bys = new byte[1024];

int len = 0;

while ((len = bis.read(bys)) != -1) {

System.out.print(new String(bys, 0, len));

}


// 释放资源

bis.close();

}

}




(7)案例:4种实现


基本字节流一次读写一个字节: 共耗时:117235毫秒

基本字节流一次读写一个字节数组: 共耗时:156毫秒

高效字节流一次读写一个字节: 共耗时:1141毫秒

高效字节流一次读写一个字节数组: 共耗时:47毫秒



package cn.itcast_06;


import java.io.BufferedInputStream;

import java.io.BufferedOutputStream;

import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;


/*

 * 需求:把e:\\哥有老婆.mp4复制到当前项目目录下的copy.mp4中

 * 

 * 字节流四种方式复制文件:

 * 基本字节流一次读写一个字节: 共耗时:117235毫秒

 * 基本字节流一次读写一个字节数组: 共耗时:156毫秒

 * 高效字节流一次读写一个字节: 共耗时:1141毫秒

 * 高效字节流一次读写一个字节数组: 共耗时:47毫秒 ***必须掌握****

 */

public class CopyMp4Demo {

public static void main(String[] args) throws IOException {

//测试时间

long start = System.currentTimeMillis();

// method1("e:\\哥有老婆.mp4", "copy1.mp4");

// method2("e:\\哥有老婆.mp4", "copy2.mp4");

// method3("e:\\哥有老婆.mp4", "copy3.mp4");

method4("e:\\哥有老婆.mp4", "copy4.mp4");

long end = System.currentTimeMillis();

System.out.println("共耗时:" + (end - start) + "毫秒");

}


// 高效字节流一次读写一个字节数组:

public static void method4(String srcString, String destString)

throws IOException {

BufferedInputStream bis = new BufferedInputStream(new FileInputStream(

srcString));

BufferedOutputStream bos = new BufferedOutputStream(

new FileOutputStream(destString));


byte[] bys = new byte[1024];

int len = 0;

while ((len = bis.read(bys)) != -1) {

bos.write(bys, 0, len);

}


bos.close();

bis.close();

}


// 高效字节流一次读写一个字节:

public static void method3(String srcString, String destString)

throws IOException {

BufferedInputStream bis = new BufferedInputStream(new FileInputStream(

srcString));

BufferedOutputStream bos = new BufferedOutputStream(

new FileOutputStream(destString));


int by = 0;

while ((by = bis.read()) != -1) {

bos.write(by);


}


bos.close();

bis.close();

}


// 基本字节流一次读写一个字节数组

public static void method2(String srcString, String destString)

throws IOException {

FileInputStream fis = new FileInputStream(srcString);

FileOutputStream fos = new FileOutputStream(destString);


byte[] bys = new byte[1024];

int len = 0;

while ((len = fis.read(bys)) != -1) {

fos.write(bys, 0, len);

}


fos.close();

fis.close();

}


// 基本字节流一次读写一个字节

public static void method1(String srcString, String destString)

throws IOException {

FileInputStream fis = new FileInputStream(srcString);

FileOutputStream fos = new FileOutputStream(destString);


int by = 0;

while ((by = fis.read()) != -1) {

fos.write(by);

}


fos.close();

fis.close();

}

}




A:复制文本文件


package cn.itcast_04;


import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;


/*

 * 需求:把c:\\a.txt内容复制到d:\\b.txt中

 * 

 * 数据源:

 *  c:\\a.txt -- 读取数据 -- FileInputStream

 * 目的地:

 *  d:\\b.txt -- 写出数据 -- FileOutputStream

 */

public class CopyFileDemo {

public static void main(String[] args) throws IOException {

// 封装数据源

FileInputStream fis = new FileInputStream("c:\\a.txt");

FileOutputStream fos = new FileOutputStream("d:\\b.txt");


// 复制数据

byte[] bys = new byte[1024];

int len = 0;

while ((len = fis.read(bys)) != -1) {

fos.write(bys, 0, len);

}


// 释放资源

fos.close();

fis.close();

}

}


B:复制图片

C:复制视频


package cn.itcast_04;


import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;


/*

 * 需求:把e:\\哥有老婆.mp4复制到当前项目目录下的copy.mp4中

 * 

 * 数据源:

 *  e:\\哥有老婆.mp4--读取数据--FileInputStream

 * 目的地:

 *  copy.mp4--写出数据--FileOutputStream

 */

public class CopyMp4Demo {

public static void main(String[] args) throws IOException {

// 封装数据源

FileInputStream fis = new FileInputStream("e:\\哥有老婆.mp4");

// 封装目的地

FileOutputStream fos = new FileOutputStream("copy.mp4");


// 复制数据

byte[] bys = new byte[1024];

int len = 0;

while ((len = fis.read(bys)) != -1) {

fos.write(bys, 0, len);

}


// 释放资源

fos.close();

fis.close();

}

}



3:自学字符流

IO流分类

字节流:

InputStream

FileInputStream

BufferedInputStream

OutputStream

FileOutputStream

BufferedOutputStream

字符流:

Reader

FileReader

BufferedReader

Writer

FileWriter

BufferedWriter



Java帮帮今日头条号



Java帮帮微信公众号



Java帮帮交流群

目录
相关文章
|
28天前
|
存储 缓存 Java
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
这篇文章详细介绍了Java中的IO流,包括字符与字节的概念、编码格式、File类的使用、IO流的分类和原理,以及通过代码示例展示了各种流的应用,如节点流、处理流、缓存流、转换流、对象流和随机访问文件流。同时,还探讨了IDEA中设置项目编码格式的方法,以及如何处理序列化和反序列化问题。
63 1
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
|
2月前
|
Java
java基础(11)函数重载以及函数递归求和
Java支持函数重载,即在同一个类中可以声明多个同名方法,只要它们的参数类型和个数不同。函数重载与修饰符、返回值无关,但与参数的类型、个数、顺序有关。此外,文中还展示了如何使用递归方法`sum`来计算两个数之间的和,递归的终止条件是当第一个参数大于第二个参数时。
31 1
java基础(11)函数重载以及函数递归求和
|
1月前
|
搜索推荐 索引
【文件IO】实现:查找文件并删除、文件复制、递归遍历目录查找文件
【文件IO】实现:查找文件并删除、文件复制、递归遍历目录查找文件
34 2
|
1月前
|
Java 数据处理 开发者
揭秘Java IO流:字节流与字符流的神秘面纱!
揭秘Java IO流:字节流与字符流的神秘面纱!
32 1
|
1月前
|
自然语言处理 Java 数据处理
Java IO流全解析:字节流和字符流的区别与联系!
Java IO流全解析:字节流和字符流的区别与联系!
69 1
|
2月前
|
安全 Java API
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
String常量池、String、StringBuffer、Stringbuilder有什么区别、List与Set的区别、ArrayList和LinkedList的区别、HashMap底层原理、ConcurrentHashMap、HashMap和Hashtable的区别、泛型擦除、ABA问题、IO多路复用、BIO、NIO、O、异常处理机制、反射
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
|
22天前
|
Java
Java 中 IO 流的分类详解
【10月更文挑战第10天】不同类型的 IO 流具有不同的特点和适用场景,我们可以根据具体的需求选择合适的流来进行数据的输入和输出操作。在实际应用中,还可以通过组合使用多种流来实现更复杂的功能。
39 0
|
2月前
|
Java 大数据 API
Java 流(Stream)、文件(File)和IO的区别
Java中的流(Stream)、文件(File)和输入/输出(I/O)是处理数据的关键概念。`File`类用于基本文件操作,如创建、删除和检查文件;流则提供了数据读写的抽象机制,适用于文件、内存和网络等多种数据源;I/O涵盖更广泛的输入输出操作,包括文件I/O、网络通信等,并支持异常处理和缓冲等功能。实际开发中,这三者常结合使用,以实现高效的数据处理。例如,`File`用于管理文件路径,`Stream`用于读写数据,I/O则处理复杂的输入输出需求。
|
1月前
|
存储 Java 程序员
【Java】文件IO
【Java】文件IO
35 0
|
3天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
28 4