开发者社区> 问答> 正文

java 缓存接口设计疑问

我想问,下面两种设计的区别 。
第一种:

 public interface ICache<T> {
    T getItem(Serializable key) ;
    void setItem(Serializable key, T item) ;
}

第二种:

 public interface ILocalCache<K, V> {
    public V get(K key) ;
    void setItem(K key, V item) ;
}

第一种跟第二种的区别是key 一个是泛型, 一个是支持序列化。 请问:当分布式缓存时第二种泛型的key是否也持之序列化 ?

展开
收起
蛮大人123 2016-03-19 11:41:10 2618 0
1 条回答
写回答
取消 提交回答
  • 我说我不帅他们就打我,还说我虚伪

    理论上支持,因为泛型指代一切类或接口,当然也可以认为是Serializable
    第一种方式,具体实现可以直接作为序列化接口操作,目标明确。
    第二种方式,必须做分歧判断,如果参数是序列化接口,然后作为序列化接口操作。
    如果不是那么也要能处理。
    如果key必须使用序列化,也就是说具体实现只支持Serializable这种类型,那么推荐第一种。
    这时,使用第二种方式没有任何意义,还容易造成对接口功能的误解而使用错误。
    如果是要求对Serializable以外的类型也能处理,那么只能用第二种方式。

    2019-07-17 19:07:54
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
基于英特尔 SSD 的虚拟机缓存解决SSD 立即下载
用户态高速块缓存方案 立即下载
高性能Web架构之缓存体系 立即下载