重現java.io.IOException: Stream closed異常

來源:互聯網
上載者:User
上午,美國的QA報告了一個的異常:

Caused by: java.io.IOException: Stream closed
at java.io.BufferedInputStream.getInIfOpen(BufferedInputStream.java:134)
at java.io.BufferedInputStream.fill(BufferedInputStream.java:218)
at java.io.BufferedInputStream.read(BufferedInputStream.java:235)
at ........

 這個異常發生在從某一個input stream流讀取資訊的時候發生的。在我們目前的系統中出現這個異常是比較不正常,特別是這個異常並不是很容易重現。我和本地的QA都沒有重現出來。

雖然不能重現bug,但是憑藉經驗來說,這個異常是發生在這樣一種情境之下:多個線程索引同一個input stream,當某一個thread在執行完之後,把這個inputstream關閉了;而此時正在從這個input stream流中讀取資訊的線程就會拋出 java.io.IOException: Stream closed 異常。

我寫了一小段測試程式,類比這個情境,如下:

public class IOTest ...{
    public static void main(String[] args) ...{
        File f = new File("c:/test/StoreTest-1.xml");
        java.io.BufferedReader br = null;
        try ...{
            br = new java.io.BufferedReader(new java.io.FileReader(f));
        } catch (FileNotFoundException e) ...{}

        final java.io.BufferedReader br1 = br;
        final java.io.BufferedReader br2 = br;

        Thread t = new Thread() ...{
            public void run() ...{
                try ...{
                    for (String line = null; (line = br1.readLine()) != null;) ...{
                        System.out.println("Process stdout: " );
                        try ...{
                            Thread.sleep(1000);
                        } catch (InterruptedException e) ...{}
                    }
                } catch (IOException ioe) ...{
                    ioe.printStackTrace();
                }
            }
        };

        Thread t2 = new Thread() ...{
            public void run() ...{
                try ...{
                    for (String line = null; (line = br2.readLine()) != null;) ...{}
                    System.out.println("Process stdout2: ");
                    br2.close();
                } catch (IOException ioe) ...{
                    ioe.printStackTrace();
                }
            }
        };

        t.start();
        t2.start();
    }
}

當執行這段程式之後,會看到如下輸出:
Process stdout:
Process stdout2:
java.io.IOException: Stream closed
 at java.io.BufferedReader.ensureOpen(BufferedReader.java:97)
 at java.io.BufferedReader.readLine(BufferedReader.java:293)
 at java.io.BufferedReader.readLine(BufferedReader.java:362)
 at test.common.util.IOTest$1.run(IOTest.java:38)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.