加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

Java泛型传递参数

发布时间:2020-12-15 00:40:33 所属栏目:Java 来源:网络整理
导读:希望有人可以帮助我摆脱这种困扰. 我做了这个方法: public static T void myMethod(MapClassT,MyInterfaceT map) {} 使用参数T以确保用作键的类与用作MyInterface中的参数的类相同. 现在我想传递一个不同类作为键的映射,当然还有MyInterface的相应实现. 但
希望有人可以帮助我摆脱这种困扰.

我做了这个方法:

public static <T> void myMethod(Map<Class<T>,MyInterface<T>> map) {
}

使用参数T以确保用作键的类与用作MyInterface中的参数的类相同.

现在我想传递一个不同类作为键的映射,当然还有MyInterface的相应实现.

但它不起作用,因类型参数而导致语法错误.这是代码,我希望是自我解释.

import java.util.HashMap;
    import java.util.Map;

    public class Test {

    public static void main(String[] args) {
        Map<Class<?>,MyInterface<?>> map = new HashMap<Class<?>,MyInterface<?>>();

    //      Map<Class<Object>,MyInterface<Object>> map = new HashMap<Class<Object>,MyInterface<Object>>();

        map.put(Object.class,new MyObjectImpl());

        //if I use Map<Class<Object>,MyInterface<Object>> I get a compiler error here
        //because map<String> is not map<Object> basically
        map.put(String.class,new MyStringImpl());

        //this would be possible using <?>,which is exactly what I don't want
    //      map.put(String.class,new MyIntegerImpl());

        //<?> generates anyways a compiler error
        myMethod(map);
    }

    //use T to make sure the class used as key is the same as the class of the parameter "object" in doSomething  
    public static <T> void myMethod(Map<Class<T>,MyInterface<T>> map) {

    }

    interface MyInterface<T> {
        void doSomething(T object);
    }

    static class MyObjectImpl implements MyInterface<Object> {
        @Override
        public void doSomething(Object object) {
            System.out.println("MyObjectImpl doSomething");
        }
    }

    static class MyStringImpl implements MyInterface<String> {
        @Override
        public void doSomething(String object) {
            System.out.println("MyStringImpl doSomething");
        }
    }

    static class MyIntegerImpl implements MyInterface<Integer> {
        @Override
        public void doSomething(Integer object) {
            System.out.println("MyIntegerImpl doSomething");
        }
    }
}

解决方法

你不能这样做,因为在键和值之间没有Map的put()方法中定义的约束.如果您想确保正确填充地图(即创建此类约束),请隐藏一些将检查正确性的API后面的地图,例如:
public <T> void registerInterface(Class<T> clazz,MyInterface<T> intf) {
    map.put(clazz,intf);
}

然后,只需调用registerInterface而不是手动填充地图.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读