如果我们对一个比较复杂的模型做cache,会有如下需求:
1. 利用多个key去查询这一模型的cache
2. 继而要求可以利用多个key去删除cache时
如果按照最简单的模型,每个key对应一个cache数据,这样当某一个key对应cache中的数据变动时,另外一个key对应的cache数据必定成为脏数据。
举例:key1->cacheObject,key2->cacheObject,当put(key1,cacheObject)时,key2对应的数据必定是脏数据;或者remove(key1)时,key2对应的cacheObject也还是会存在的,也是脏数据。
于是,有个办法,就是把多个key关联起来,通过key之间的关联,达到数据一致性的目的。
我们的模型是这样的:
key1->key2,key2->cacheObject,在实际的程序中
存数据:put(key1,key2);put(key2,cacheObject)
查数据:key2=get(key1);cacheObject=get(key2);
删数据:key2=get(key1);remove(key2);