Java BufferedWriter, OutputStreamWriter может писать в закрытый FileOutputStream - PullRequest
8 голосов
/ 16 марта 2010

Я ожидал, что следующий код выдаст исключение при записи данных в поток:

File file = new File("test.txt");
FileOutputStream fs = new FileOutputStream(file);
OutputStreamWriter ow = new OutputStreamWriter(fs);
BufferedWriter writer = new BufferedWriter(ow);

fs.close();

try {
    ow.write(65);
    writer.write("test");
} catch (Exception e) {
    e.printStackTrace();
}

Я понимаю, что должен закрыть BufferedWriter, но в моем текущем окружении, возможно, FileOutputStream может быть закрыт до закрытия BufferedWriter. Разве FileOutputStream не должен выдавать IOException, которое должно перемещаться вверх по цепочке, пока не достигнет моего блока try / catch и распечатать трассировку стека?

Если я попытаюсь вызвать fs.write (65), произойдет исключение.

1 Ответ

10 голосов
/ 16 марта 2010

Попробуйте выполнить сброс после записи вызова. Буферизованный поток, возможно, еще не пытался записать содержимое в базовый поток, и, следовательно, не понял, что базовый поток был закрыт.

EDIT:

Только что попробовал. С кодом:

File file = new File("test.txt");
FileOutputStream fs = new FileOutputStream(file);
OutputStreamWriter ow = new OutputStreamWriter(fs);
BufferedWriter writer = new BufferedWriter(ow);

fs.close();

try {
    ow.write(65);
    writer.write("test");
    writer.flush();
} catch (Exception e) {
    e.printStackTrace();
}

вы получаете следующее исключение:

java.io.IOException: Bad file descriptor
    at java.io.FileOutputStream.writeBytes(Native Method)
    at java.io.FileOutputStream.write(FileOutputStream.java:260)
    at sun.nio.cs.StreamEncoder.writeBytes(StreamEncoder.java:202)
    at sun.nio.cs.StreamEncoder.implFlushBuffer(StreamEncoder.java:272)
    at sun.nio.cs.StreamEncoder.implFlush(StreamEncoder.java:276)
    at sun.nio.cs.StreamEncoder.flush(StreamEncoder.java:122)
    at java.io.OutputStreamWriter.flush(OutputStreamWriter.java:212)
    at java.io.BufferedWriter.flush(BufferedWriter.java:236)
    at Test.main(Test.java:16)
...