我想知道是否可以在 Java 的方法范围内引入类型变量。也就是说,将它们的范围限制在方法主体内。
但是,与其试图抽象地描述问题,不如让我用我的具体问题来说明。我有几个看起来有点像这样的类:
public class Settings {
public static abstract class Setting<T> {
public T value;
public abstract T fallbackvalue();
}
private final List<Setting<?>> settings;
}
我现在想编写一个函数 in Settings
,用于将所有设置的值设置为抽象方法提供的备用值。我的第一个想法是这样做:
public void reset() {
for(Setting<?> setting : settings)
setting.value = setting.fallbackvalue();
}
然而,再想一想,为什么这不起作用是相当明显的。for setting.value的捕获与<?>
for 的捕获不同setting.fallbackvalue()
。因此,我需要一些方法来统一捕获。可以这样解决:
private static <T> void reset1(Setting<T> s) {
s.value = setting.fallbackvalue();
}
public void reset() {
for(Setting<?> setting : settings)
reset1(setting);
}
显式类型变量<T>
forreset1
方便地统一捕获,但仅仅为了满足类型系统,引入这个函数,污染命名空间,混乱屏幕,降低代码可读性,显然是世界上最丑陋的事情。
有没有办法我可以在体内做到这一点reset
?我想做的就是这样:
public void reset() {
for(Setting<?> setting : settings) {
<T> {
Setting<T> foo = setting;
foo.value = foo.fallbackvalue();
}
}
}
这不是世界上最漂亮的东西,但至少在我看来,它远没有上面的变体那么紧张。唉,这是不可能的;但是有什么可能呢?