我有如下定义的三种 java 类型:
主.java:
import java.util.Arrays;
import java.util.List;
public class Main
{
private Object callFunction()
{
OperationDefinitions func = OperationDefinitions.CONCATENATE;
List<Object> values = Arrays.asList(new Object[] {"ABC", "-", "DEF"});
return func.call (values);
}
public static void main (String[] args)
{
Main main = new Main();
System.out.println (main.callFunction());
}
}
操作.java
import java.util.List;
public interface Operation
{
abstract Object call(List<Object> params);
}
操作定义.java
import java.util.List;
enum OperationDefinitions implements Operation
{
CONCATENATE() {
public Object call(List<Object> params)
{
StringBuilder builder = new StringBuilder();
for (Object param : params) builder.append((String)param);
return builder.toString();
}
},
;
}
(这几乎正是 Effective Java 2nd ed.Item 30 中给出的示例)上面的代码在 eclipse 中编译和运行得很好,但是使用 Sun javac 我得到以下错误:
Main.java:12: cannot find symbol
symbol : method call(java.util.List<java.lang.Object>)
location: class OperationDefinitions
return func.call (values);
^
1 error
如果我将 Main.java 的第 12 行从更改return func.call(values);
为return ((Operation)func).call(values)
编译正常。此外,如果我将三种类型(Operation、Main 和 OperationDefinitions)放在一起作为单个主类的三个子类,它也可以很好地编译。
所以我确实有解决我的问题的方法,但我想知道,为什么 javac 需要在这里强制转换,而 eclipse 不需要?这是 javac 还是 eclipse 中的错误?
我已经尝试过 Sun javac 1.5.0_19 和 1.6.0_16