我一直在努力定义一个通用接口,但是我没能达到我想要的效果.以下是该问题的简化示例.
假设我有一个通用的Message类
public class Message<T> {
private T content;
public void setContent(T content) {
this.content = content;
}
public T getContent() {
return content;
}
}
Run Code Online (Sandbox Code Playgroud)
然后我想定义一个用于转移事物的接口:
public interface Transfer<Message<T>> {
public void send(Message message);
}
Run Code Online (Sandbox Code Playgroud)
问题是编译器不接受这个,并且总是抱怨第二个'<'字符,无论我尝试什么变化.如何指定此接口以使其绑定到泛型类型(基于Message)并且还可以访问参数化类型?
我的计划是使用如下界面:
public class Carrier<Message<T>> implements Transfer<Message<T>> {
public void send(Message message) {
T content = message.getContent();
print(content);
}
public static void print(String s) {
System.out.println("The string equals '" + s + "'");
}
public static void print(Integer i) {
System.out.println("The integer equals " + i);
}
public static void main(String[] args) {
Carrier<Message<String>> stringCarrier = new Carrier<Message<String>>();
Message<String> stringMessage = new Message<String>("test");
stringCarrier.send(stringMessage);
Carrier<Message<Integer>> integerCarrier = new Carrier<Message<Integer>>();
Message<Integer> integerMessage = new Message<Integer>(123);
integerCarrier.send(integerMessage);
}
}
Run Code Online (Sandbox Code Playgroud)
我已经做了一些搜索和阅读(其中包括Angelika的泛型常见问题),但我无法判断这是不可能的,还是我做错了.
更新2009-01-16:删除了"Thing"的原始用法而不是"Message <T>"(之所以使用它是因为我能够编译而不会在界面上出现语法错误).
它看起来像你想要的:
public class Carrier<Thing extends Message<Foo>, Foo>
implements Transfer<Thing>
Run Code Online (Sandbox Code Playgroud)
这样编译器就会知道它thing
是a Message<Foo>
,因此会有一个getContent()方法.
您需要将其用作:
Carrier<Message<String>, String>
Run Code Online (Sandbox Code Playgroud)
但是你现在有点断绝了.你正在实现,Transfer<Thing>
但是你正在尝试使用,thing
就像Message<Thing>
看看你的send
方法一样 - 你用String和Integer调用它.那些类没有getContent()
方法.
我怀疑你应该实际应用Transfer<Message<Thing>>
而不是Transfer<Thing>
归档时间: |
|
查看次数: |
577 次 |
最近记录: |