緩沖流
緩沖流, 也叫高效流, 按照資料型別分類:
- 位元組緩沖流:
BufferedInputStream
,BufferedOutputStream
- 字符緩沖流:
BufferedReader
,BufferedWriter
緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖區讀寫,減少系統IO次數,從而提高讀寫的效率,
位元組緩沖流
// 構造方法
public BufferedInputStream(InputStream in)
// 創建一個 新的緩沖輸入流
public BufferedOutputStream(OutputStream out)
// 創建一個新的緩沖輸出流,
// 位元組輸出緩沖流
OutputStream out = new BufferedOutputStream(new FileOutputStream("FileAndIoStream\\test\\4.txt"));
out.write("hello world\r\n".getBytes());
out.write("hello world\r\n".getBytes());
out.write("hello world\r\n".getBytes());
out.write("hello world\r\n".getBytes());
out.close();
// 位元組輸入緩沖流
InputStream in = new BufferedInputStream(new FileInputStream("FileAndIoStream\\test\\4.txt"));
byte[] chs = new byte[1024];
int len = 0;
while ((len = in.read(chs)) != -1) {
System.out.println(new String(chs, 0, len));
}
in.close();
字符緩沖流
// 構造方法
public BufferedReader(Reader in)
// 創建一個 新的緩沖輸入流
public BufferedWriter(Writer out)
// 創建一個新的緩沖輸出流,
特有方法
- BufferedReader:
public String readLine()
: 讀一行文字, - BufferedWriter:
public void newLine()
: 寫一行行分隔符,由系統屬性定義符號,
BufferedReader bufferedReader = new BufferedReader(new FileReader("FileAndIoStream\\test\\4.txt"));
String line = null;
while ((line = bufferedReader.readLine()) != null) {
System.out.println(line);
}
bufferedReader.close();
BufferedWriter bw = new BufferedWriter(new FileWriter("FileAndIoStream\\test\\4.txt"));
bw.write("你好");
bw.close();
文本排序練習
3.侍中、侍郎郭攸之、費祎、董允等,此皆良實,志慮忠純,是以先帝簡拔以遺陛下,愚以為宮中之事,事無大小,悉以咨之,然后施行,必得裨補闕漏,有所廣益,
8.愿陛下托臣以討賊興復之效,不效,則治臣之罪,以告先帝之靈,若無興德之言,則責攸之、祎、允等之慢,以彰其咎;陛下亦宜自謀,以咨諏善道,察納雅言,深追先帝遺詔,臣不勝受恩感激,
4.將軍向寵,性行淑均,曉暢軍事,試用之于昔日,先帝稱之曰能,是以眾議舉寵為督,愚以為營中之事,悉以咨之,必能使行陣和睦,優劣得所,
2.宮中府中,俱為一體,陟罰臧否,不宜異同,若有作奸犯科及為忠善者,宜付有司論其刑賞,以昭陛下平明之理,不宜偏私,使內外異法也,
1.先帝創業未半而中道崩殂,今天下三分,益州疲弊,此誠危急存亡之秋也,然侍衛之臣不懈于內,忠志之士忘身于外者,蓋追先帝之殊遇,欲報之于陛下也,誠宜開張圣聽,以光先帝遺德,恢弘志士之氣,不宜妄自菲薄,引喻失義,以塞忠諫之路也,
9.今當遠離,臨表涕零,不知所言,
6.臣本布衣,躬耕于南陽,茍全性命于亂世,不求聞達于諸侯,先帝不以臣卑鄙,猥自枉屈,三顧臣于草廬之中,咨臣以當世之事,由是感激,遂許先帝以驅馳,后值傾覆,受任于敗軍之際,奉命于危難之間,爾來二十有一年矣,
7.先帝知臣謹慎,故臨崩寄臣以大事也,受命以來,夙夜憂嘆,恐付托不效,以傷先帝之明,故五月渡瀘,深入不毛,今南方已定,兵甲已足,當獎率三軍,北定中原,庶竭駑鈍,攘除奸兇,興復漢室,還于舊都,此臣所以報先帝而忠陛下之職分也,至于斟酌損益,進盡忠言,則攸之、祎、允之任也,
5.親賢臣,遠小人,此先漢所以興隆也;親小人,遠賢臣,此后漢所以傾頹也,先帝在時,每與臣論此事,未嘗不嘆息痛恨于桓、靈也,侍中、尚書、長史、參軍,此悉貞良死節之臣,愿陛下親之信之,則漢室之隆,可計日而待也,
public class test {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new FileReader("FileAndIoStream\\test\\csb"));
TreeSet<String> set = new TreeSet<>(new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
String num1 = o1.split("\\.")[0];
String num2 = o2.split("\\.")[0];
return Integer.parseInt(num1) - Integer.parseInt(num2);
}
});
String line = null;
while ((line = br.readLine()) != null) {
set.add(line);
}
br.close();
BufferedWriter bw = new BufferedWriter(new FileWriter("FileAndIoStream\\test\\csb"));
for (String s : set) {
bw.write(s);
bw.newLine();
bw.flush();
}
bw.close();
}
public static void mapToSort() throws IOException {
BufferedReader br = new BufferedReader(new FileReader("FileAndIoStream\\test\\csb"));
TreeMap<Integer, String> map = new TreeMap<>();
String line = null;
while ((line = br.readLine()) != null) {
String[] split = line.split("\\.");
map.put(Integer.parseInt(split[0]), line);
}
br.close();
BufferedWriter bw = new BufferedWriter(new FileWriter("FileAndIoStream\\test\\csb"));
for (Integer integer : map.keySet()) {
bw.write(map.get(integer));
bw.newLine();
bw.flush();
}
bw.close();
}
}
轉換流
由于 FileReader 和 FileWriter 無法指定編碼 僅可使用平臺默認編碼 因此若讀取/寫入其他編碼檔案會亂碼
// java.io.InputStreamReader
// 構造方法
public InputStreamReader(InputStream in, String charsetName)
String charsetName 指定字符集, 不區分大小寫
// java.io.OutputStreamWriter
// 構造方法
public InputStreamReader(OutputStream in, String charsetName)
String charsetName 指定字符集, 不區分大小寫
Reader r = new InputStreamReader(new FileInputStream("FileAndIoStream\\test\\csbGBK.txt"), "gbk");
char[] chs = new char[1024];
int len = 0;
while ((len = r.read(chs)) != -1) {
System.out.println(new String(chs, 0, len));
}
r.close();
Writer w = new OutputStreamWriter(new FileOutputStream("FileAndIoStream\\test\\csbGBK.txt",true), "gbk");
w.write("\n11.END");
w.close();
練習
復制檔案并轉換編碼
Reader reader = new InputStreamReader(new FileInputStream("FileAndIoStream\\test\\csbGBK.txt"),"gbk");
Writer writer = new OutputStreamWriter(new FileOutputStream("FileAndIoStream\\test\\csbUTF8.txt"));
char[] chars = new char[1024];
len = 0;
while ((len = reader.read(chars)) != -1) {
writer.write(new String(chars, 0, len));
writer.flush();
}
reader.close();
writer.close();
序列化
Java 提供了一種物件序列化的機制,用一個位元組序列可以表示一個物件,該位元組序列包含該物件的資料
、物件的型別
和物件中存盤的屬性
等資訊,位元組序列寫出到檔案之后,相當于檔案中持久保存了一個物件的資訊,
反之,該位元組序列還可以從檔案中讀取回來,重構物件,對它進行反序列化,物件的資料
、物件的型別
和物件中存盤的資料
資訊,都可以用來在記憶體中創建物件,
java.io.ObjectOutputStream
類,將Java物件的原始資料型別寫出到檔案,實作物件的持久存盤,java.io.ObjectInputStream
反序列化流,將之前使用ObjectOutputStream序列化的原始資料恢復為物件
// 構造方法
public ObjectOutputStream(OutputStream out)
// 創建一個指定OutputStream的ObjectOutputStream
public ObjectInputStream(InputStream in)
// 創建一個指定InputStream的ObjectInputStream
public class Demo {
public static void main(String[] args) throws IOException, ClassNotFoundException {
writeObject();
readerObject();
}
// 序列化
public static void writeObject() throws IOException {
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("FileAndIoStream\\test\\Person.txt"));
// 序列化單個物件
// oos.writeObject(new Person("張三", 17, 1));
// 序列化多個物件
List<Person> list = new ArrayList<Person>();
list.add(new Person("張三",11,1));
list.add(new Person("李四",15,0));
list.add(new Person("王五",17,1));
list.add(new Person("劉六",10,0));
oos.writeObject(list);
oos.close();
}
// 反序列化
public static void readerObject() throws IOException, ClassNotFoundException {
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("FileAndIoStream\\test\\Person.txt"));
// 反序列化單個物件
// Person p = (Person) ois.readObject();
// System.out.println(p);
// 反序列化多個物件
Object obj = ois.readObject();
List<Person> list = (List<Person>) obj;
for (Person person : list) {
System.out.println(person);
}
ois.close();
}
}
class Person implements Serializable {
// 靜態內容不能序列化
private static String className;
private String name;
private int age;
// transient 關鍵字 瞬態, 不可被序列化
private transient int sex;
private static final long serialVersionUID = 1L;
// 反序列化 不呼叫構造方法
public Person() {}
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public Person(String name, int age, int sex) {
this.name = name;
this.age = age;
this.sex = sex;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
", sex=" + sex +
'}';
}
}
反序列化時, 若找不到class檔案, 則反序列話失敗, 拋出例外 ClassNotFoundException
當jvm反序列化物件時, 能找到class檔案, 但在序列化物件后class檔案發生了改變, 則反序列化失敗, 拋出例外 InvalidClassException
當類作為Serializable 的實作類初始化時, 會同時生成一個序列號, 反序列化時檢測到序列號不一致
列印流
平時我們在控制臺列印輸出,是呼叫print
方法和println
方法完成的,這兩個方法都來自于java.io.PrintStream
類,該類能夠方便地列印各種資料型別的值,是一種便捷的輸出方式
PrintStream類
public PrintStream(String fileName)
: 使用指定的檔案名創建一個新的列印流,
public class Demo {
public static void main(String[] args) throws IOException {
PrintWriter p = new PrintWriter("FileAndIoStream\\test\\print1.txt");
p.print("abc");
p. println(10);
p.println(true);
p.close();
PrintWriter pw = new PrintWriter(new FileWriter("FileAndIoStream\\test\\print2.txt"),true);
pw.println("你好");
// 設定輸出位置, 將 輸出到控制臺 改為 輸出到檔案
System.setOut(new PrintStream(new FileOutputStream("FileAndIoStream\\test\\print2.txt", true)));
System.out.println("輸出到檔案1");
System.out.println("輸出到檔案2");
pw.close();
}
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/550534.html
標籤:其他
上一篇:Java-SpringBoot-Range請求頭設定實作視頻分段傳輸
下一篇:使用Java接入小程式訂閱訊息!