摘要:包幾乎包含了所有操作輸入輸出需要的類。所有這些流類代表了輸入源和輸出目標(biāo)。輸入流表示從一個(gè)源讀取數(shù)據(jù),輸出流表示向一個(gè)目標(biāo)寫(xiě)數(shù)據(jù)。但本節(jié)講述最基本的和流與相關(guān)的功能。讀取控制臺(tái)輸入的控制臺(tái)輸入由完成。有多種構(gòu)造方法可用來(lái)創(chuàng)建對(duì)象。
package com.learn; import org.omg.CORBA.PUBLIC_MEMBER; import java.io.*; /** * Created by fiz on 7/10/17. ** Java.io 包幾乎包含了所有操作輸入、輸出需要的類。所有這些流類代表了輸入源和輸出目標(biāo)。 * Java.io 包中的流支持很多種格式,比如:基本類型、對(duì)象、本地化字符集等等。 * 一個(gè)流可以理解為一個(gè)數(shù)據(jù)的序列。輸入流表示從一個(gè)源讀取數(shù)據(jù),輸出流表示向一個(gè)目標(biāo)寫(xiě)數(shù)據(jù)。 * Java 為 I/O 提供了強(qiáng)大的而靈活的支持,使其更廣泛地應(yīng)用到文件傳輸和網(wǎng)絡(luò)編程中。 * 但本節(jié)講述最基本的和流與 I/O 相關(guān)的功能。我們將通過(guò)一個(gè)個(gè)例子來(lái)學(xué)習(xí)這些功能。 *
*
*
* 讀取控制臺(tái)輸入: *
* Java 的控制臺(tái)輸入由 System.in 完成。 * 為了獲得一個(gè)綁定到控制臺(tái)的字符流,你可以把 System.in 包裝在一個(gè) BufferedReader 對(duì)象中來(lái)創(chuàng)建一個(gè)字符流。 * 下面是創(chuàng)建 BufferedReader 的基本語(yǔ)法: */ public class FileStreamTest { public static void readDir(String dir) { /** * 讀取指定目錄下的文件夾,并只返回文件, */ File file = new File(dir); if (file.isDirectory()) { System.out.println("這個(gè)是個(gè)文件夾"); } else { System.out.println(); } } public static void main(String[] args) throws IOException { BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(System.in)); System.out.println("請(qǐng)輸入你的要輸入的內(nèi)容"); String input = bufferedReader.readLine(); System.out.println(input); /** * FileInputStream *該流用于從文件讀取數(shù)據(jù),它的對(duì)象可以用關(guān)鍵字 new 來(lái)創(chuàng)建。 *有多種構(gòu)造方法可用來(lái)創(chuàng)建對(duì)象。 *可以使用字符串類型的文件名來(lái)創(chuàng)建一個(gè)輸入流對(duì)象來(lái)讀取文件 */ InputStream inputStream = new FileInputStream("/Users/fiz/Documents/JavaProject/JavaProject.iml"); byte[] buffer = new byte[1000]; while (inputStream.read(buffer) > 0) { System.out.println(inputStream.read(buffer)); } /** * 輸出文件 */ File f = new File("/Users/fiz/Documents/JavaProject/demo.txt"); FileOutputStream fop = new FileOutputStream(f); // 構(gòu)建FileOutputStream對(duì)象,文件不存在會(huì)自動(dòng)新建 OutputStreamWriter outputStreamWriter = new OutputStreamWriter(fop); outputStreamWriter.write("demo"); outputStreamWriter.close(); /** * PipedOutputStream/PipedInputStream * 不能用于同一個(gè)線程中,主要是要去不同線程獲取 */ final PipedOutputStream pipedOutputStream = new PipedOutputStream(); final PipedInputStream pipedInputStream = new PipedInputStream(pipedOutputStream); Thread thread1 = new Thread(new Runnable() { @Override public void run() { try { pipedOutputStream.write("Hello world, pipe!".getBytes()); } catch (IOException e) { } } }); Thread thread2 = new Thread(new Runnable() { @Override public void run() { try { int data = pipedInputStream.read(); while (data != -1) { System.out.print((char) data); data = pipedInputStream.read(); } } catch (IOException e) { } } }); thread1.start(); thread2.start(); /** * InputStream */ InputStream inputStream1 = new FileInputStream("/Users/fiz/Documents/JavaProject/JavaProject.iml"); byte[] bytesRead = new byte[1024]; int data = inputStream1.read(bytesRead); while (data != -1) { //do something with data... System.out.println((char) data); data = inputStream1.read(); } inputStream1.close(); /** * FileOutputStream */ File file = new File("demo.txt"); FileOutputStream fileOutputStream = new FileOutputStream(file); int num = 10; while (num > 0) { fileOutputStream.write("deno+ ".getBytes()); num = num - 1; } fileOutputStream.close(); /** *FileInputStream 讀取文件 */ FileInputStream fileInputStream = new FileInputStream(file); int read = fileInputStream.read(); while (read != -1) { System.out.println((char) fileInputStream.read()); read = fileInputStream.read(); } /** * inputStreamReader */ InputStream inputStream2 = new FileInputStream("demo.txt"); Reader inputStreamReader = new InputStreamReader(inputStream2); int data2 = inputStreamReader.read(); while (data2 != -1) { char theChar = (char) data2; System.out.println("inputStreamReader"); System.out.println(theChar); data2 = inputStreamReader.read(); } /** * */ OutputStream outputStream = new FileOutputStream("demo.txt"); Writer outputStreamWriter1 = new OutputStreamWriter(outputStream); outputStreamWriter1.write("Hello World"); outputStreamWriter1.close(); /** * FileWriter */ FileWriter fileWriter = new FileWriter(file); fileWriter.write("This is an example "); fileWriter.flush();// 刷掉緩沖區(qū)的內(nèi)容 fileWriter.close(); /** * FileReader */ FileReader fileReader = new FileReader(file); int fileReader_data = fileReader.read(); while (fileReader_data != -1) { fileReader_data = fileReader.read(); System.out.println((char) fileReader_data); } /** *BufferedReader */ BufferedReader bufferedReader1 = new BufferedReader(new FileReader(file)); String line = bufferedReader1.readLine(); System.out.println("BufferedReader" + line); bufferedReader1.close(); // 循環(huán)讀取 // while (line != null) { // // process line // } /** *BufferedWriter */ BufferedWriter bufferedWriter = new BufferedWriter(new FileWriter("demo.txt", true)); bufferedWriter.write("this is a demo process"); int count = 10; while (count > 0) { bufferedWriter.write("this is a demo process "); count = count - 1; } bufferedWriter.close(); File file1 = new File("test.txt"); FileWriter fw = new FileWriter(file1); BufferedWriter bw = new BufferedWriter(fw); bw.write("demo"); System.out.println("File written Successfully"); /** *FilterWriter 虛擬類 */ /** * */ LineNumberReader lineNumberReader = new LineNumberReader(new FileReader(file1)); String line1 = lineNumberReader.readLine(); while (line != null) { line = lineNumberReader.readLine(); System.out.println(line + lineNumberReader.getLineNumber()); } } }
做個(gè)記錄
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/67342.html
摘要:不建議對(duì)這兩個(gè)對(duì)象嘗試使用單個(gè)線程,因?yàn)檫@樣可能會(huì)造成該線程死鎖。構(gòu)造函數(shù)創(chuàng)建尚未連接到管道輸入流的管道輸出流。通常,數(shù)據(jù)由某個(gè)線程從對(duì)象讀取,并由其他線程將其寫(xiě)入到相應(yīng)的。 管道流 管道流的主要作用是可以進(jìn)行兩個(gè)線程間的通訊,分為管道輸出流(PipedOutputStream)、管道輸入流(PipedInputStream),如果想要進(jìn)行管道輸出,則必須要把輸出流連在輸入流之上,在...
閱讀 1879·2019-08-30 15:53
閱讀 3204·2019-08-30 15:44
閱讀 2813·2019-08-26 13:31
閱讀 1957·2019-08-26 12:10
閱讀 802·2019-08-26 11:01
閱讀 2133·2019-08-23 15:32
閱讀 1590·2019-08-23 13:43
閱讀 2545·2019-08-23 11:58