gpt4 book ai didi

java - 保留对象的最新版本

转载 作者:行者123 更新时间:2023-11-30 01:46:35 25 4
gpt4 key购买 nike

我需要以多线程方式从源读取数据。源可以包含各种资源的消息。为了保证快速阅读,我使用多线程阅读。同一资源可能有多个消息,在这种情况下,我只想保留最新的消息。

class Message {

String id;
String data;
long timeStamp
}

我正在尝试找出处理此问题的最佳方法。鉴于我将以多线程方式阅读,不确定哪种数据结构最适合? ConcurrentHashMap 以 id 为键?在这种情况下,我需要检查 key 是否存在。如果是,则比较消息并根据需要进行更新。如果可能发生这种情况,当比较两个版本时,第三个版本的消息到达并更新,因为当时我不会采取写锁定。在检查和更新周围添加同步块(synchronized block)是唯一的方法吗?有什么有效的建议吗?

最佳答案

如果只是读取,可以在变量前使用volatile关键字来指示JVM,它可以被多个线程同时访问。这样您就不会遭受过时数据的困扰。

另一方面,如果您想同时修改变量,则需要锁定(使用同步 block 或非内在锁)。 volatile 提供可见性、锁定 - 可见性原子性。

附注:取自this书。

关于java - 保留对象的最新版本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57720597/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com