我有一个返回控制器的通用工厂,我想在不使用@SuppressWarnings的情况下避免使用Unchecked Cast警告。
在下面的示例中,工厂使用两种不同的方式返回控制器。第一个((BallController<T>) getBaseballController();
)会导致Unchecked Cast警告。第二个((BallController<T>) someOtherClass.getFootballController();
)不会引起任何警告。
public class BallControllerFactory {
public BaseballController getBaseballController() {
return new BaseballController();
}
public <T extends Ball> BallController<T> getBallController(T ball) {
if(ball instanceof Baseball) {
return (BallController<T>) getBaseballController();
}
else if(ball instanceof Football) {
SomeOtherClass someOtherClass = new SomeOtherClass();
return (BallController<T>) someOtherClass.getFootballController();
}
//No controller found
return null;
}
}
如您所见,只需将getXXXController方法移动到委托类,就会消除警告。这是SomeOtherClass,只是让你看不到任何特别的事情发生。
public class SomeOtherClass {
public FootballController getFootballController() {
return new FootballController();
}
}
我的问题是,为什么当我使用委托方法返回控制器时,我没有得到Unchecked Cast警告,但是当我使用本地方法时,我会这样做?
为了完整起见,这里是其他类定义(都是空类)。
public class BallController<T extends Ball>
public class BaseballController extends BallController<Baseball>
public class FootballController extends BallController<Football>
public class Ball
public class Baseball extends Ball
public class Football extends Ball
答案 0 :(得分:1)
虽然您的警告消息由于某种原因不一致(您应该同时收到警告),但您的情况的修复方法是更改:
public <T extends Ball> BallController<T> getBallController(T ball) {
到
public <T extends Ball> BallController<?> getBallController(T ball) {
并删除演员:
return (BallController<T>) getBaseballController();
return (BallController<T>) someOtherClass.getFootballController();
像:
return getBaseballController();
return someOtherClass.getFootballController();