更新节点数据的方法:
- 同步方法:Stat setData(final String path, byte data[], int
version
) - 异步方法:void setData(final String path, byte data[], int
version
, StatCallback cb, Object ctx)
参数说明:
- path:指定数据节点路径
- data[]:一个字节数组,即需要使用该数据来覆盖节点现在的数据内容
- version:指定节点的数据版本
- cb:注册一个异步回调函数
- ctx:用于传递上下文信息的对象
version参数用于指定节点的数据版本,表名本次更新操作是针对指定的数据版本进行的。
指定数据版本更新的意义何在呢?
通俗的讲"CAS":对于值V,每次更新前都会比对其值是否是预期值A,只有符合预期,才会将V原子化的更新到新值B
防止并发,多个线程同时提交,导致结果被覆盖
zookeeper的setData接口中的version参数是CAS衍化来的。
zookeeper每个节点都有数据版本的概念,在调用更新操作的时候,就可以添加version这个参数,该参数可以对应于CAS