Java SE IOは、学習の概要をストリーム

IO流

IOストリーム、バイトストリーム文字ストリーム

バイトストリーム:入力ストリームのInputStream共通の親クラスはサブクラスのFileInputStreamにBufferedInputStreamを持っています

出力ストリームのOutputStream共通の親クラスがサブクラスのFileOutputStream BfferedOutputStreamを持っています

文字ストリーム:リーダーの共通の親入力ストリームサブクラスはBufferedReaderのにInputStreamReaderを持っています

ライター共通の親クラスの出力ストリームサブクラスは、BufferedWriterののOutputStreamWriterを持っています

InputStream和のOutputStream

それぞれの読み取りと書き込みのこの方法バイト

ファイル

ケースファイルのコピー

private static void copy() throws FileNotFoundException, IOException {
        FileInputStream fis = new FileInputStream("暴躁源泉.jpg");
        FileOutputStream fos = new FileOutputStream("copy.jpg");
        
        int b ;
        while((b = fis.read())!= -1) {
            fos.write(b);
        }      
        //以上三行为核心代码
        fis.close();
        fos.close();
    }

この方法は、1バイトの輸送に相当し、効率が非常に遅いです。

この方法は、改善するために

public static void main(String[] args) throws IOException {
        //copy();
        //copy2();
        FileInputStream fis = new FileInputStream("A*Teens - Upside Down.mp3");
        FileOutputStream fos = new FileOutputStream("copy2.mp3");
        
        byte[] arr = new byte[fis.available()];
        fis.read(arr);
        fos.write(arr);
        
        fis.close();
        fos.close();
        
    }

この方法は、方法1.1と比較してサイズFISバイト輸送の総バイト数、高効率に相当します。しかし、あまりにも多くのバイトならば、メモリが原因崩壊する可能性があります。

この方法が変更されます

    public static void main(String[] args) throws IOException {
        //demo1();
        //demo2();
        FileInputStream fis = new FileInputStream("A*Teens - Upside Down.mp3");
        FileOutputStream fos = new FileOutputStream("yyy.mp3");
        
        
        byte[] arr = new byte[1024*8];
        int len;
        while((len = fis.read(arr)) != -1) {
            fos.write(arr,0,len);
        }
        
        
        fis.close();
        fos.close();
    }

この方法は、原因メモリオーバーフローに対して一回、十分な大きさではない可能性の非常に多くのバイトを搬送配列arr [8×1024]メモリのサイズをとります。

BufferedInputStreamを


    private static void demo1() throws FileNotFoundException, IOException {
        // TODO Auto-generated method stub
        FileInputStream fis = new FileInputStream("A*Teens - Upside Down.mp3");
        FileOutputStream fos = new FileOutputStream("copy。mp3");
        BufferedInputStream bis = new BufferedInputStream(fis);
        BufferedOutputStream  bos = new BufferedOutputStream(fos);
        
        int b ;
        while((b=bis.read()) != -1) {
            bos.write(b);
        }
        
        bos.close();
        bis.close();
    }

FISは、オブジェクトを定義する必要があり、後に渡されたオブジェクトは、BufferedInputStreamををFIS

若しくは

BufferedInputStream bis =
    new BufferedInputStream(new FileInputStream("A*Teens - Upside Down.mp3"));
BufferedOutputStream bos =
    new BufferedOutputStream(new FileOutputStream("copy.mp3"));
        

リーダーライター和

文字ストリームは、符号化モードに応じて、キャラクタごとに基づいて、バイトストリームに比べて(GDKは、UTF-8)は、異なるコンパイル・モードを持っています。

        FileReader fr = new FileReader("xxx.txt");
        int c;
        
        while((c = fr.read()) != -1) {
            System.out.print((char)c);
        }
        
        fr.close();
        FileReader fr = new FileReader("xxx.txt");
        FileWriter fw = new FileWriter("yyy.txt");
        
        char[] arr = new char[1024];
        int len;
        while((len = fr.read(arr)) != -1) {
            fw.write(arr,0,len);
        }
        
        fr.close();
        fw.close();

文字が1024バイト以上を回すことができないからといって、それは長さがいくつかの文字で役割編曲:現在のLENか否かが判断され、空のfr.read(ARR)-1 LENには、残りのARRの長さです。

BufferedReaderの

BufferedReader br = new BufferedReader(new FileReader("zzz.txt"));

追加されましたreadlineの(リーダー)、および改行(ライター)メソッド。

それぞれ現在の行、改行の文字列を読んで、それが書かれたとき。

    String line;
        while((line = br.readLine())!=null) {
            bw.write(line);
            bw.newLine();
        }
LinNumberReader
    LineNumberReader lnr = new LineNumberReader(new FileReader("zzz.txt"));
        
        String line;
        lnr.setLineNumber(100);
        while((line = lnr.readLine())!= null)
        {
            System.out.println(lnr.getLineNumber()+":"+line);
        }
        lnr.close();

初期値は1、現在の行番号の現実をLNR。ブラケットは、さらにコピーすることができます。

フォーマットの変更をコードについて

ときにエンコード形式は、時に2つの異なるファイル

BufferedReader br =
                new BufferedReader(new InputStreamReader(new FileInputStream("utf-8.txt"),"utf-8"));
        BufferedWriter bw =
                new BufferedWriter(new OutputStreamWriter(new FileOutputStream("gbk.txt"),"gbk"));
        

FileInputStreamの後に文字列プラス符号化フォーマットに対応する電流を定義します。

検索ファイルを再帰的に小さい場合


import java.io.File;
import java.util.Scanner;

public class Test5 {

    public static void main(String[] args) {
        File dir = getDir();
        printfile(dir);
    }
    
    public static File getDir() {
        Scanner in = new Scanner(System.in);
        System.out.println("请输入一个文件夹路径");
        while(true) {
            String line = in.nextLine();
            File dir = new File(line);
            if(!dir.exists()) {
                System.out.println("您录入的文件夹路劲不存在,请重新输入");
            }else if(dir.isFile()){
                System.out.println("是文件");
            }else
            {
                return dir;
            }
        }
    }
    
    
    public static void printfile(File dir) {
        File[] subFiles =dir.listFiles();
        for (File subFile : subFiles) {
            if(subFile.isFile() && subFile.getName().endsWith(".txt")){
                System.out.println(subFile);
            }else if(subFile.isDirectory()){
                printfile(subFile);
            }
        }
    }
}

おすすめ

転載: www.cnblogs.com/xijue/p/12342717.html