У меня есть следующий метод записи, который записывает данные в файл с помощью gson.Как я могу протестировать следующий код блокировки и многопоточности
private static final File CONFIG_FILE = new File("./config.json");;
private static final ReadWriteLock READ_WRITE_LOCK = new ReentrantReadWriteLock(true);
private static final Lock READ_LOCK = READ_WRITE_LOCK.readLock();
private static final Lock WRITE_LOCK = READ_WRITE_LOCK.writeLock();
...
public void write(JsonData data) {
Verifier.verifyNotNull(data,"data : null");
Verifier.verifyNotNull(data.getData(),"JsonData data : null");
Verifier.verifyNotEmpty(data.getIdentifier(),"JsonData identifier : empty");
Writer writer = null;
Gson gson = null;
try {
WRITE_LOCK.lock();
writer = new FileWriter(CONFIG_FILE);
gson = new GsonBuilder().setPrettyPrinting().create();
gson.toJson(data, writer);
}
catch (IOException e) {
e.printStackTrace();
}
finally {
try {
if (writer != null) {
writer.flush();
writer.close();
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (RuntimeException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
finally {
WRITE_LOCK.unlock();
}
}
Замок, показанный выше, представляет собой блокировку Reeentrant, предоставляемую библиотеками Java. Если я хочу, чтобы тестировать вышеуказанный метод безопасности потоков, как это проверить?
Просьба сообщить,
Спасибо!
Для этого вам нужно несколько блоков try. Если 'writer.flush()' генерирует исключение, вы не освободите блокировку. –
Здравствуйте, спасибо, что заметили это. Я переместил 'writer.flush()' в блок catch. Поскольку методы «.flush» и «.close» бросают «IOExceptions», я думаю, что блокировка будет выпущена в блоке catch для «IOException», показанного выше. Отредактировано код – Rookie
Попробуйте вложить блоки try, чтобы у вас был внешний, посвященный только блокировке. Это позволяет избежать необходимости разблокировать в разных местах или быть удивленным ошибкой в 'flush()' бросать исключение RuntimeException', которое вы пропустили. –