本篇主要介紹的是關于nio在文件讀寫方面的簡單應用,具體底層實現(xiàn)原理,并未深究。
新的輸入/輸出(NIO)庫是在JDK 1.4中引入的。它與原來的I/O庫最重要的區(qū)別是數(shù)據(jù)打包和傳輸?shù)姆绞降牟煌瓉淼?/span> I/O 以流 的方式處理數(shù)據(jù),而 NIO 以塊 的方式處理數(shù)據(jù)。按塊處理數(shù)據(jù)比按(流式的)字節(jié)處理數(shù)據(jù)要快得多。但是面向塊的I/O缺少一些面向流的I/O所具有的優(yōu)雅性和簡單性。
示例代碼:使用IO和NIO讀取一個文件中的內(nèi)容

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

從以上示例代碼中,我們可以看到對于nio非常重要的兩個核心概念:通道與緩沖區(qū)。
(1)通道
Channel是對原I/O包中的流的模擬,可以通過它讀取和寫入數(shù)據(jù)。拿NIO與原來的I/O做個比較,通道就像是流。
通道與流的不同之處在于通道是雙向的。而流只是在一個方向上移動(一個流必須是InputStream或者OutputStream的子類), 而通道可以用于讀、寫或者同時用于讀寫。
因為它們是雙向的,所以通道可以比流更好地反映底層操作系統(tǒng)的真實情況。特別是在UNIX模型中,底層操作系統(tǒng)通道是雙向的。
(2)緩沖區(qū)
在NIO庫中,所有數(shù)據(jù)都是用緩沖區(qū)處理的。在讀取數(shù)據(jù)時,它是直接讀到緩沖區(qū)中的。在寫入數(shù)據(jù)時,它是寫入到緩沖區(qū)中的。任何時候訪問NIO中的數(shù)據(jù),您都是將它放到緩沖區(qū)中。
緩沖區(qū)實質(zhì)上是一個數(shù)組。通常它是一個字節(jié)數(shù)組,但是也可以使用其他種類的數(shù)組。但是一個緩沖區(qū)不僅僅是一個數(shù)組。緩沖區(qū)提供了對數(shù)據(jù)的結(jié)構化訪問,而且還可以跟蹤系統(tǒng)的讀/寫進程。
最常用的緩沖區(qū)類型是ByteBuffer。 一個ByteBuffer可以在其底層字節(jié)數(shù)組上進行get/set操作(即字節(jié)的獲取和設置)。
ByteBuffer不是NIO中唯一的緩沖區(qū)類型。事實上,對于每一種基本Java類型都有一種緩沖區(qū)類型:
ByteBuffer
CharBuffer
ShortBuffer
LongBuffer
FloatBuffer
DoubleBuffer
每一個Buffer類都是Buffer接口的一個實例。
文件的讀寫
nio讀取文件涉及三個步驟:
(1) 從FileInputStream獲取Channel。
(2) 創(chuàng)建Buffer。
(3) 將數(shù)據(jù)從Channel讀到Buffer 中。
文件的寫操作與讀操作類似。
下面我以文件的拷貝為例,展示一下nio的讀寫過程:

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

關于nio更加詳細深入研究請參考:http://zhangshixi.javaeye.com/category/101360