Why can't I throw an exception while using the ternary operator

前端 未结 4 1072
南旧
南旧 2021-02-13 03:49

This doesn\'t compile and gives the following error : Illegal start of expression. Why?

public static AppConfig getInstance() {
        return mConf         


        
相关标签:
4条回答
  • 2021-02-13 04:13

    This is because a ternary operator in java takes the form expression ? expression : expression, and you are giving a statement as the final part. This doesn't make sense as a statement doesn't give a value, while expressions do. What is Java meant to do when it finds the condition to be false and tries to give the second value? There is no value.

    The ternary operator is designed to allow you to quickly make a choice between two variables without using a full if statement - that isn't what you are trying to do, so don't use it, the best solution is simply:

    public static AppConfig getInstance() {
        if (mConfig != null) {
            return mConfig;
        } else {
            throw new RuntimeException("error");
        }
    }
    

    The ternary operator isn't designed to produce side effects - while it can be made to produce them, people reading it won't expect that, so it's far better to use a real if statement to make it clear.

    0 讨论(0)
  • 2021-02-13 04:15

    You are trying to return a throw new RuntimeException("error"). That is why you are getting error. Because in true case you are returning AppConfig and in false case you are returning exception.

    0 讨论(0)
  • 2021-02-13 04:21

    In case it's helpful to someone, here is an answer using java 8+ Optional:

    public static AppConfig getInstance() {
        return Optional.ofNullable(mConfig).orElseThrow(() -> new RuntimeException("error"));
    }
    
    0 讨论(0)
  • 2021-02-13 04:34

    You may write an utility method

    public class Util
    {
      /** Always throws {@link RuntimeException} with the given message */
      public static <T> T throwException(String msg)
      {
          throw new RuntimeException(msg);
      }
    }
    

    And use it like this:

    public static AppConfig getInstance() 
    {
        return mConfig != null ? mConfig : Util.<AppConfig> throwException("error");
    }
    
    0 讨论(0)
提交回复
热议问题