printstream和printwriter的api幾乎相同,都能輸出各種形式的數(shù)據(jù),構(gòu)造方法也幾乎相同
printwriter多了個(gè)接受writer參數(shù)
api比較:
那么,它們的區(qū)別究竟在哪里?來(lái)自stackflow
主要意思就是,2個(gè)類的功能基本相同,printstream能做的printwriter也都能實(shí)現(xiàn),并且printwriter的功能更為強(qiáng)大。但是由于printwriter出現(xiàn)的比較晚,較早的system.out使用的是printstream來(lái)實(shí)現(xiàn)的,所以為了兼容就沒(méi)有廢棄printstream。
2個(gè)類最大的差別是,printstream在輸出字符,將字符轉(zhuǎn)換為字節(jié)時(shí)采用的是系統(tǒng)默認(rèn)的編碼格式,這樣當(dāng)數(shù)據(jù)傳輸另一個(gè)平臺(tái),而另一個(gè)平臺(tái)使用另外一個(gè)編碼格式解碼時(shí)就會(huì)出現(xiàn)問(wèn)題,存在不可控因素。而printwriter可以在傳入writer時(shí)可由程序員指定字符轉(zhuǎn)換為字節(jié)時(shí)的編碼格式,這樣兼容性和可控性會(huì)更好。
下面這個(gè)程式顯示了printstream與printwriter兩個(gè)物件在處理相同輸出目的時(shí)的作法,程式將會(huì)在熒幕上顯示 "簡(jiǎn)體中文" 四個(gè)字元:
1
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
|
streamwriterdemo.java package onlyfun.caterpillar; import java.io.*; public class streamwriterdemo { public static void main(string[] args) { try { byte [] sim = {( byte ) 0xbc , ( byte ) 0xf2 , // 簡(jiǎn) ( byte ) 0xcc , ( byte ) 0xe5 , // 體 ( byte ) 0xd6 , ( byte ) 0xd0 , // 中 ( byte ) 0xce , ( byte ) 0xc4 } ; // 文 inputstreamreader inputstreamreader = new inputstreamreader( new bytearrayinputstream(sim), "gb2312" ); printwriter printwriter = new printwriter( new outputstreamwriter(system.out, "gb2312" )); printstream printstream = new printstream(system.out, true , "gb2312" ); int in; while ((in = inputstreamreader.read()) != - 1 ) { printwriter.println(( char )in); printstream.println(( char )in); } inputstreamreader.close(); printwriter.close(); printstream.close(); } catch (arrayindexoutofboundsexception e) { e.printstacktrace(); } catch (ioexception e) { e.printstacktrace(); } } } |
總結(jié)
以上就是本文關(guān)于printstream和printwriter的區(qū)別簡(jiǎn)介的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!
原文鏈接:http://blog.csdn.net/zhhtao89/article/details/50129319