在程序中全部的數據都是以流的方式進行傳輸或保存的,程序須要數據的時候要使用輸入流讀取數據,而當程序須要將一些數據保存起來的時候,就要使用輸出流完成。數組
InputStream 和OutputStream,兩個是爲字節流設計的,主要用來處理字節或二進制對象,
Reader和 Writer.兩個是爲字符流(一個字符佔兩個字節)設計的,主要用來處理字符或字符串.
字符流處理的單元爲2個字節的Unicode字符,操做字符、字符數組或字符串,
字節流處理單元爲1個字節,操做字節和字節數組。
因此字符流是由Java虛擬機將字節轉化爲2個字節的Unicode字符爲單位的字符而成的,
因此它對多國語言支持性比較好!
若是是音頻文件、圖片、歌曲,就用字節流好點,
若是是關係到中文(文本)的,用字符流好點編碼
全部文件的儲存是都是字節(byte)的儲存,在磁盤上保留的並非文件的字符而是先把字符編碼成字節,再儲存這些字節到磁盤。在讀取文件(特別是文本文件)時,也是一個字節一個字節地讀取以造成字節序列
字節流可用於任何類型的對象,包括二進制對象,而字符流只能處理字符或者字符串;
字節流提供了處理任何類型的IO操做的功能,但它不能直接處理Unicode字符,而字符流就能夠
字節流是最基本的,全部的InputStrem和OutputStream的子類都是,主要用在處理二進制數據,它是按字節來處理的
但實際中不少的數據是文本,
又提出了字符流的概念,
它是按虛擬機的encode來處理,也就是要進行字符集的轉化
這兩個之間經過 InputStreamReader,OutputStreamWriter來關聯,
其實是經過byte[]和String來關聯
在實際開發中出現的漢字問題實際上都是在字符流和字節流之間轉化不統一而形成的 設計
Reader類的read()方法返回類型爲int :做爲整數讀取的字符(佔兩個字節共16位),範圍在 0 到 65535 之間 (0x00-0xffff),若是已到達流的末尾,則返回 -1code
inputStream的read()雖然也返回int,但因爲此類是面向字節流的,一個字節佔8個位,因此返回 0 到 255 範圍內的 int 字節值。若是由於已經到達流末尾而沒有可用的字節,則返回值 -1。所以對於不能用0-255來表示的值就得用字符流來讀取!好比說漢字.視頻
字節流和字符流的主要區別是什麼呢?對象
一.字節流在操做時不會用到緩衝區(內存),是直接對文件自己進行操做的。而字符流在操做時使用了緩衝區,經過緩衝區再操做文件。圖片
二.在硬盤上的全部文件都是以字節形式存在的(圖片,聲音,視頻),而字符值在內存中才會造成。內存
上面兩點能說明什麼呢?資源
針對第一點,開發
咱們知道,若是一個程序頻繁對一個資源進行IO操做,效率會很是低。此時,經過緩衝區,先把須要操做的數據暫時放入內存中,之後直接從內存中讀取數據,則能夠避免屢次的IO操做,提升效率
針對第二點,
真正存儲和傳輸數據時都是以字節爲單位的,字符只是存在與內存當中的,因此,字節流適用範圍更爲寬廣