当前位置:  开发笔记 > 编程语言 > 正文

如何泛化指定可序列化列表

如何解决《如何泛化指定可序列化列表》经验,为你挑选了1个好方法。

我有以下界面:

public interface Result extends Serializable{
    T getResult();
}

使用该接口,我无法定义类型的变量

Result>

因为List不可序列化.

但是,如果我将界面更改为:

public interface Result extends Serializable{
    T getResult();
}

现在变得不可能通过编译时检查来实现,因为不能保证T是可序列化的,并且类的整个点是存储结果,以便我可以稍后将其取回,可能在通过互联网传输之后.

我的问题是,有没有办法声明一个变量,以便它有两种类型,或者有其他方法可以做到这一点,我没有看到?所以,也许是这样的:

(List extends Serializable) value = new ArrayList();

我试图将这个问题的重担放在实现上,以便该接口的未来消费者不会意识到这个问题.

谢谢你的帮助!

下面是我正在尝试做的更详细的示例:我正在调用服务器,我希望将结果存储在结果对象中,但我不想处理强制转换.因此,可以在服务器上调用的每个方法都将使用泛型定义结果的类型.此结果对象还将存储有关结果的其他元数据,例如,可能返回的信息太多.在许多情况下,我想使用列表,但List接口不可序列化,尽管许多实现都是.

那么,如何指定所使用的类型必须是Serializable,但是仍然允许使用List(而不是List的特定实现)?



1> Patrick..:

您需要将变量类型声明为Result>.

类型检查知道List不是serializable,但List可以是子类型serializable.

这是一些示例代码.接口实现只是使用匿名内部类完成的.您可以看到getResultList在第二个对象上返回a

   Result res = new Result() {

        Integer myInteger;

        private static final long serialVersionUID = 1L;

        @Override
        public Integer getResult() {
            return myInteger;
        }

        @Override
        public void addResult(Integer input) {
            this.myInteger = input;
        }
    };

    Integer check = res.getResult();


    Result> res2 = new Result>() {

        ArrayList myList;

        private static final long serialVersionUID = 1L;

        @Override
        public ArrayList getResult() {
            return myList;
        }

        @Override 
        public void addResult(ArrayList input) {
            this.myList = input;
        }

    };

    List check2 = res2.getResult();

编辑:通过实现void addResult(T input)接口方法使示例更加完整

推荐阅读
360691894_8a5c48
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有