浅谈装饰模式应用于IO中
測試題是這樣描述的:編寫程序拷貝一個文件, 盡量使用效率高的方式.
我當時使用IO來做這道題的,下面先介紹一下什么是裝飾模式:
裝飾模式(Decorator pattern)又名包裝模式(Wrapper Pattern)
?主要功能也是增加被包裝類的功能,雖然繼承也是可以實現這一點,但兩者還是有區別的,因為為了增加子類的功能可能會創建非常多的類,非常多的繼承層次,缺乏靈活性,相互性,而裝飾模可以任意組合,非常靈活!
下面我結合IO中的一些接口來對應裝飾模式的各種角色:
裝飾模式角色對比:
抽象構件角色(Component)相當于IntputStream;
具體構件角色(Concretor )相當于 字節流 FileInputStream
裝飾角色???? (Decorator)相當于? FilterIntputStream 包裝(只是為具體裝飾角色提供實現條件)
具體裝飾角色? (Concretor Decorator)相當于BufferedInputStream DateInputStream
如果要求效率高,如果只單純的輸出字節,程序每次只能將一個字節讀入到文件中去,如果有一百個字節,就要讀一百次。如果加上緩存包裝,就可以先將字節存儲在內存中, 待需要時一次性傳入到文件或硬盤中,極大的提高了效率!!
所以我選擇使用過濾流,裝飾模式: BufferedInputStream/BufferedOutputStream;
其實就是把類進行包裝賦予它們新的功能:下面是我對這道題目的實現:
package com.itheima;
/**
?* 7、 編寫程序拷貝一個文件, 盡量使用效率高的方式.
?*/
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
public class Test7
{
/*
* 如果要求效率高,如果只單純的輸出字節,程序每次只能將一個字節讀入到文件中去,
* 如果有一百個字節,就要讀一百次。如果加上緩存包裝,就可以先將字節存儲在內存中, 待需要時一次性傳入到文件或硬盤中,極大的提高了效率!!
* 所以我選擇使用過濾流,裝飾模式: BufferedInputStream/BufferedOutputStream;
*/
public static void main(String[] args) throws IOException
{
// 創建輸入流;
FileInputStream file = new FileInputStream("c:/源文件名.txt");
// 裝飾file;
BufferedInputStream file2 = new BufferedInputStream(file);
byte[] b = new byte[100];//字符轉換為字節才能被讀取
int length;
String a = null;
while (-1 != (length = file2.read(b, 0, 100)))
{
a = new String(b, 0, length);
System.out.println(a);// 在控制臺輸出一下
}
// 創建輸出流并修飾
FileOutputStream fileCopy = new FileOutputStream("c:/拷貝文件名.txt");
BufferedOutputStream fileCopy2 = new BufferedOutputStream(fileCopy);
byte[] copy = a.getBytes();
fileCopy2.write(copy);
file2.close();
fileCopy2.close();
}
}
?
總結
以上是生活随笔為你收集整理的浅谈装饰模式应用于IO中的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Object类中的两个方法——wait和
- 下一篇: 泛型中的模糊继承,解析T的意义