• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天下

            記錄修行的印記

            AutoCloseable,Closeable和Flushable接口

            探究java IO之AutoCloseable,Closeable和Flushable接口
            java-io與網絡編程

            有3個接口對于流類相當重要。其中兩個接口是Closeable和Flushable,它們是在java.io包中定義的,并且是由JDK5添加的。第3個接口是AutoColseable,它是由JDK7添加的新接口,被打包到java.lang包中。

            AutoCloseable接口對JDK7新添加的帶資源的try語句提供了支持,這種try語句可以自動執行資源關閉過程。只有實現了AutoCloseable接口的類的對象才可以由帶資源的try語句進行管理。AutoCloseable接口只定義了close()方法:
            void close() throws Exception
            這個方法關閉調用對象,釋放可能占用的所有資源。在帶資源的try語句的末尾,會自動調用該方法,因此消除了顯式調用close()方法的需要。

            Closeable接口也定義了close()方法。實現了Closeable接口的類的對象可以被關閉。從JDK7開始,Closeable擴展了AutoCloseable。因此,在JDK7中,所有實現了Closeable接口的類也都實現了AutoCloseable接口。

            實現了Flushable接口的類的對象,可以強制將緩存的輸出寫入到與對象關聯的流中。該接口定義了flush()方法,如下所示:
            void flush() throws IOException
            刷新流通常會導致緩存的輸出被物理地寫入到底層設備中。寫入流的所有I/O類都實現了Flushable接口。

            注:關于帶資源的try語句的3個關鍵點:

            由帶資源的try語句管理的資源必須是實現了AutoCloseable接口的類的對象。

            在try代碼中聲明的資源被隱式聲明為fianl。

            通過使用分號分隔每個聲明可以管理多個資源。

            此外請記住,所聲明資源的作用域被限制在帶資源的try語句中。帶資源的try語句的主要優點是:當try代碼塊結束時,資源(在此時流)會被自動關閉。因此,不太可能會忘記關閉流。使有帶資源的try語句,通常可以使源代碼更短,更清晰,更容易維護。如例:

            package io;

            import java.io.BufferedReader;
            import java.io.File;
            import java.io.FileInputStream;
            import java.io.IOException;
            import java.io.InputStreamReader;

            public class InputStreamReaderTest 
            {
                public static void main(String[] args) 
                {
                    try(BufferedReader reader = new BufferedReader(
                        new InputStreamReader(
                            new FileInputStream(
                                new File("/home/fuhd/text")),"UTF8"),1024)){
                        System.out.println(reader.readLine());    //這里直接讀一行
                    } catch(IOException e){
                        e.printStackTrace();
                    }
                }
            }

            posted on 2015-12-04 14:50 天下 閱讀(535) 評論(0)  編輯 收藏 引用 所屬分類: Java

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            午夜久久久久久禁播电影| 一本一本久久aa综合精品| 国产99久久久久久免费看| 丰满少妇人妻久久久久久4| 久久久久久一区国产精品| 久久久久久久波多野结衣高潮| 久久综合狠狠综合久久| 久久人妻少妇嫩草AV无码蜜桃| 人妻无码αv中文字幕久久| 久久精品国产欧美日韩| 久久久久久亚洲精品成人 | 亚洲午夜久久久久久久久电影网 | 久久精品国产精品亚洲下载| 2019久久久高清456| 大美女久久久久久j久久| 蜜臀久久99精品久久久久久小说 | 久久久国产打桩机| 欧美久久综合九色综合| 97久久精品人人做人人爽| 无码人妻久久一区二区三区| 少妇久久久久久被弄到高潮 | 久久人人爽人人爽人人片AV麻烦| 日韩欧美亚洲综合久久影院d3| 久久天天躁狠狠躁夜夜avapp| 欧美亚洲另类久久综合婷婷| 久久免费小视频| 久久无码av三级| 久久se精品一区精品二区| 奇米影视7777久久精品| 无码人妻久久久一区二区三区| 国内精品伊人久久久久妇| 午夜精品久久久久9999高清| 久久人妻少妇嫩草AV无码蜜桃| 精品久久综合1区2区3区激情| 国产AV影片久久久久久| 久久久久久国产精品无码下载| 国产999精品久久久久久| 国产视频久久| 久久受www免费人成_看片中文| 亚洲精品综合久久| 久久亚洲精品中文字幕|