Java。多線程環境中對象的序列化
否。正如@Tom Hawtin所說,您將需要執行自己的鎖定,以確保在序列化對象時不會更改對象。@H_502_7@它是如何工作的?也就是說,ObjectOutputStream是否將執行序列化塊,直到不再有任何線程在Counter上運行了?
ObjectOutputStream@H_403_16@不會在引擎蓋下鎖定。如有必要,由應用程序決定。@H_502_7@如果Counter的同步不使用固有鎖,而是使用其他鎖怎么辦?
然后,在序列化發生時,您的應用程序還需要使用其他鎖定來鎖定更新。@H_502_7@
如果您要序列化的狀態僅由一個對象的狀態和兩個字段組成,則鎖爭用和粒度應該不成問題。但是,如果對象很復雜,那么鎖爭用就很成問題了,獲取鎖而又沒有死鎖風險的問題也很成問題。這種情況需要仔細設計。@H_502_7@解決方法
我有一個對象,其內部可變狀態正在由一個或多個線程不斷更新。對象已同步,目標是從另一個線程定期保存其狀態(通過序列化):
public class Counter implements Serializable { private int dogCount; private int catCount; public synchronized void updateFromDogThread( int count ) { dogCount = count; } public synchronized void updateFromCatThread( int count ) { catCount = count; }}
問題:
在這種情況下,序列化安全嗎?它是如何工作的?也就是說,ObjectOutputStream執行序列化是否會阻塞直到不再有線程運行Counter?如果Counter同步不使用固有鎖,而是使用其他鎖怎么辦?相關文章:
1. windows誤人子弟啊2. php傳對應的id值為什么傳不了啊有木有大神會的看我下方截圖3. 如何用筆記本上的apache做微信開發的服務器4. python - linux 下用wsgifunc 運行web.py該如何修改代碼5. 關于mysql聯合查詢一對多的顯示結果問題6. 實現bing搜索工具urlAPI提交7. 冒昧問一下,我這php代碼哪里出錯了???8. mysql優化 - MySQL如何為配置表建立索引?9. MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)10. 數據庫 - Mysql的存儲過程真的是個坑!求助下面的存儲過程哪里錯啦,實在是找不到哪里的問題了。
