没有静态成员可以使用类型参数,但是可以使用泛型类型参数调用静态成员吗?例如:-
abstract class Agent<A>{
void callAgent();
Agent(){
A.add();
}
}
这里的add()是一个静态方法。
在类似的主题上也有一些C#问题和答案,但是我不太确定如何在Java中使用它。
不,如果A是泛型类型,则无法执行。(Bozho对fast的回答是:),可能认为A是具体类型。
可行的方法如下。
abstract class Agent extends Blah<ConcreteA>{
void callAgent();
Agent() {
ConcreteA.add();
}
}
但这可能不是您想要的。
阅读您的评论后,听起来您真正想要做的是:
abstract class Agent<A extends SomeClassThatSupportsAdd> {
void callAgent();
protected abstract A createNew();
Agent() {
A a = createNew();
A.add();
}
}
您的子类将必须重写createNew()
。
如果您仍然不喜欢它,可以看一下AspectJ,它可以让您做一些构造器魔术(请参阅spring如何实现@Configurable),但这会变得更加棘手,并使事情变得复杂。
另一种选择是Scala。Java不对静态方法进行继承,因此您无法获得参数化的模块(某些语言中的函数组,这称为函子…
ocaml)。但是,Scala支持确实允许参数功能多态继承的单例“对象”。
问题内容: 我遇到了一个涉及静态泛型方法的奇怪情况。这是代码: 我为什么不必在表达式中指定任何类型参数?这是某种类型推断吗?如果我想对此进行明确说明,如何指定类型参数? 问题答案: 是的,根据JLS第15.12.2.8节,这是基于分配目标的类型推断。明确地说,您可以这样称呼:
问题内容: 我有一个包含静态创建方法的类。 当我使用时,它可以被编译。但是当我使用时,它编译失败,如何指定泛型? 问题答案: 假设您询问有关在类型推断失败的情况下显式指定类型的信息,则可以使用(请注意,该类型在after之后而不是before之前)。
问题内容: 运行Demo类将在SomeClass中调用静态方法newInstance来调用构造函数并打印问候 定义方法将包括返回类型+方法名称以及参数 newInstance的返回类型是 SomeClass 在我看来很奇怪,因为我的班级叫做SomeClass 而不是 SomeClass 为什么在SomeClass 前面需要 ?看来,如果我不包含它,将会出现一个常见错误,称为“无法对非静态类型T进行
问题内容: 在Java中,我希望具有以下内容: 但是我明白了 我对基本用途以外的泛型没有什么了解,因此对此没有多大意义。我无法在互联网上找到有关该主题的很多信息,这无济于事。 有人可以通过类似的方式澄清这种使用是否可行吗?另外,为什么我最初的尝试失败了? 问题答案: 你不能在静态方法或静态字段中使用类的泛型类型参数。该类的类型参数仅在实例方法和实例字段的范围内。对于静态字段和静态方法,它们在类的所
我一直在尝试泛型,很快我就遇到了一些我无法解释的事情 例如: 我不明白
本文向大家介绍Java静态泛型使用方法实例解析,包括了Java静态泛型使用方法实例解析的使用技巧和注意事项,需要的朋友参考一下 前言:当工具类对多个模型类进行排序,比较等操作的时候,需要书写大量重复代码,因为懒人总要想怎么省事的,所以考虑使用泛型这个玩意简化代码 案例:当前存在两个模型类,Fruit和Person,他们都需要排序方法而且业务逻辑各不相同,因此需要分别写两个排序方法,但因为排序相同的