我正在学习java线程,我写了下面的代码并尝试运行此代码。我没有使用任何同步概念,但输出格式一致。请帮我弄清楚实际原因。
package check;
import java.io.BufferedWriter;
import java.io.FileNotFoundException;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Date;
public class Hello {
public static void main(String[] args) throws FileNotFoundException, IOException {
Write write = new Write();
String str[] = new String[5];
String str2[] = new String[5];
for (int i = 0 ; i < 5; i ++) {
str[i] = System.getProperty("line.separator") + " hello this is a new line written at " + new Date().toString();
str2[i] = System.getProperty("line.separator") + " this is code after new line " + new Date().toString();
}
new Th(str, write).start();
new Th(str2 , write).start();
}
}
class Th extends Thread {
private String[] message;
private Write write;
Th(String[] message, Write write) {
this.message = message;
this.write = write;
}
public void run() {
try {
write.write(message);
} catch (Exception e) {
e.printStackTrace();
}
}
}
class Write {
public void write(String[] message) throws IOException {
FileWriter fileWriter = null;
BufferedWriter bufferedWriter = null;
try {
fileWriter = new FileWriter("d:/a.txt", true);
bufferedWriter = new BufferedWriter(fileWriter);
for (String msg : message) {
System.out.println(Thread.currentThread().getName());
bufferedWriter.write(msg);
Thread.sleep(500);
}
} catch (Exception e) {
System.out.println(e);
} finally {
bufferedWriter.close();
fileWriter.close();
}
}
}
我知道,Writer类的write方法在内部使用同步块,如:
public void write(String str, int off, int len) throws IOException {
synchronized (lock) {
char cbuf[];
if (len <= WRITE_BUFFER_SIZE) {
if (writeBuffer == null) {
writeBuffer = new char[WRITE_BUFFER_SIZE];
}
cbuf = writeBuffer;
} else { // Don't permanently allocate very large buffers.
cbuf = new char[len];
}
str.getChars(off, (off + len), cbuf, 0);
write(cbuf, 0, len);
}
}
我的节目输出是:
this is code after new line Thu Mar 16 19:33:07 IST 2017
this is code after new line Thu Mar 16 19:33:07 IST 2017
this is code after new line Thu Mar 16 19:33:07 IST 2017
this is code after new line Thu Mar 16 19:33:07 IST 2017
this is code after new line Thu Mar 16 19:33:07 IST 2017
hello this is a new line written at Thu Mar 16 19:33:07 IST 2017
hello this is a new line written at Thu Mar 16 19:33:07 IST 2017
hello this is a new line written at Thu Mar 16 19:33:07 IST 2017
hello this is a new line written at Thu Mar 16 19:33:07 IST 2017
hello this is a new line written at Thu Mar 16 19:33:07 IST 2017
我的问题是:为什么第二个线程在第一个线程从write方法的同步块中出来后才写入数据。 谢谢:))
答案 0 :(得分:2)
你的问题写得很糟糕。
输出是正确的,这意味着每个线程每半秒写一行,但你没有解释的是你显示的“输出”是在一个文件中。
BufferedWriter
仅将文本存储在缓冲区中,这仅在编写器将缓冲区刷入文件的close()
期间。
以下是BufferedWriter.close()
public void close() throws IOException {
synchronized (lock) {
if (out == null) {
return;
}
try {
flushBuffer();
} finally {
out.close();
out = null;
cb = null;
}
}
}
你看到它会刷新那里的缓冲区。
为了证明这一点,你可以在循环中自己冲洗作家:
fileWriter.write(msg);
fileWriter.flush();
这就是构造函数接受int
的原因,这是缓冲区的最大大小,如果达到大小,它将自动刷新。
当然,您应该知道在一个文件中使用一个线程更容易,并且您的两个线程要求写入线程将该行放入文件中。