我正在尝试在我的应用程序中使用 Hazelcast 实现分布式缓存。我正在使用 Hazelcast 的IMap
. 我遇到的问题是每次从地图中获取值并更新值时,我都需要再做put(key, value)
一次。如果我的值对象有 10 个属性并且我必须更新所有 10 个属性,那么我必须调用put(key, value)
10 次。就像是 -
IMap<Integer, Employee> mapEmployees = hz.getMap("employees");
Employee emp1 = mapEmployees.get(100);
emp1.setAge(30);
mapEmployees.put(100, emp1);
emp1.setSex(“F”);
mapEmployees.put(100, emp1);
emp1.setSalary(5000);
mapEmployees.put(100, emp1);
如果我不这样做,则对同一 Employee 对象进行操作的其他一些节点将对其进行更新,最终结果是该员工对象不同步。有什么解决方案可以避免多次明确调用 put 吗?在 aConcurrentHashMap
中,我不需要这样做,因为如果我更改对象,地图也会更新。