问题
I am facing a rather unusual situation. I am using printWriter with System.out
to print the bytes from a file onto console, first using a ByteStreamReader and then a CharacterStreamReader. The problem is after the output of ByteStreamReader, subsequent System.out.println statements are not printing anything on console. I tried using flush on System.out.flush() but still not getting output.
Code:
FileStream fs = new FileStream(); //ByteStreamReader
String source = "./test_zh.txt";
CharacterStream cs = new CharacterStream(); //CharacterStreamReader
System.out.println("\nChinese Sentence using ByteStreamReader");
fs.printOnConsole(source); //if i comment this, then below lines gets printed
System.out.println("\nChinese Sentence using CharacterStreamReader");//Not getting printed on console
cs.printOnConsole(source); //Not getting printed on console
My code for both the Stream types is as follows:
FileSteam Class
public void printOnConsole(String source) throws IOException{
try{
inp = new FileInputStream(source);
pwr = new PrintWriter(System.out,true);
int c =0;
while( (c = inp.read()) != -1){
pwr.write(c);
pwr.write("(" + c +")");
}
}catch(FileNotFoundException f){
}catch(IOException e){
}finally{
inp.close();
pwr.flush();
pwr.close();
}
}
CharacterStream Class
public void printOnConsole(String source) throws IOException{
try{
fReader = new FileReader(source);
pwr = new PrintWriter(System.out,true);
int c;
while((c = fReader.read()) != -1){
pwr.write(c);
pwr.write("(" +c +")");
}
}catch(IOException f){
}finally{
fReader.close();
pwr.flush();
pwr.close();
}
}
回答1:
I can see 2 significant problems with your FileStream and CharacterStream classes.
Both classes call
close()on thePrintWriterthat wrapsSystem.out. When that happensSystem.outwill be closed, and no further writes to it will be permitted.Both classes squash IO exceptions. That is they catch the exception, say nothing, and continue as if nothing happened. That is extremely poor coding practice ... and it is most likely hiding the exceptions that happen when you write to the closed
System.outstream.
There are also a variety of style problems, the worst of which is your poor choice of method and class names. For example the printOnConsole methods don't print on the console. Rather they print on the standard output stream ... which may go to somewhere other than the console. (And your application can't tell!!)
来源:https://stackoverflow.com/questions/44518912/system-out-println-not-working-after-printwriter-on-system-out