3

我有一个返回控制器的通用工厂,我想在不使用 @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
4

1 回答 1

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();
于 2014-05-19T18:27:10.063 回答