图解java多线程设计模式学习第四章Balking模式
所谓Balking,不适合执行这个操作,或者没必要执行这个操作,就停止处理,直接返回。
示例程序:程序将定期将当前数据内容写入到文件中,当数据内容被写入时,会完全覆盖上次写入的内容,只有最新的内容才会被保存。另外,当写入的内容与上次写入的内容完全相同时,再向文件写入就显得多余了,所以就不再执行写入操作。也就是说,该程序以"数据内容存在不同"作为守护条件,如果数据内容相同,则不执行写入操作,直接返回(balk).
package com.balking;
import java.io.IOException;
import java.io.FileWriter;
import java.io.Writer;
public class Data {
private final String filename; // 保存的文件名称
private String content; // 数据内容
private boolean changed; // 修改后的内容若未保存,则为true
public Data(String filename, String content) {
this.filename = filename;
this.content = content;
this.changed = true;
}
// 修改数据内容
public synchronized void change(String newContent) {
content = newContent;
changed = true;
}
// 若数据内容修改过,则保存到文件中
public synchronized void save() throws IOException {
if (!changed) {
return;
}
doSave();
changed = false;
}
// 将数据内容实际保存到文件中
private void doSave() throws IOException {
System.out.println(Thread.currentThread().getName() + " calls doSave, content = " + content);
Writer writer = new FileWriter(filename);
writer.write(content);
writer.close();
}
}
package com.balking;
import java.io.IOException;
import java.util.Random;
public class ChangerThread extends Thread {
private final Data data;
private final Random random = new Random();
public ChangerThread(String name, Data data) {
super(name);
this.data = data;
}
public void run() {
try {
for (int i = 0; true; i++) {
data.change("No." + i); // 修改数据
Thread.sleep(random.nextInt(1000)); // 执行其他操作
data.save(); // 显式地保存
}
} catch (IOException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
package com.balking;
import java.io.IOException;
public class SaverThread extends Thread {
private final Data data;
public SaverThread(String name, Data data) {
super(name);
this.data = data;
}
public void run() {
try {
while (true) {
data.save(); // 要求保存数据
Thread.sleep(1000); // 休眠约1秒
}
} catch (IOException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
package com.balking;
public class Main {
public static void main(String[] args) {
Data data = new Data("data.txt", "(empty)");
new ChangerThread("ChangerThread", data).start();
new SaverThread("SaverThread", data).start();
}
}
运行结果: