【问题标题】:Method modifier ordering in Java [duplicate]Java中的方法修饰符排序[重复]
【发布时间】:2013-06-11 02:26:15
【问题描述】:

据我了解,这是定义典型方法的方式:

modifier returnValueType methodName(list of parameters) {
    // Method body;
}

但是,如果您有多个修饰符(例如publicstatic<GenericType>),它们应该有特定的顺序吗?

这是我过去考试问题之一的典型答案:

<S> public void emptyList(CyclicQueue<S> queue) {
    while(!queue.isEmpty()) { queue.pop(); }
}

您可以看到通用修饰符 &lt;S&gt; 出现在 public 之前,但我在某些地方看到了这种情况:

public <S> void emptyList(CyclicQueue<S> queue) {
    while(!queue.isEmpty()) { queue.pop(); }
}

这些修饰符的排序方式是正确的还是更传统的方式?

【问题讨论】:

    标签: java methods syntax modifier


    【解决方案1】:

    website 为您提供了修饰符排序的粗略指南。

    泛型也应该在公共方法之后声明。

    public <S> void emptyList(CyclicQueue<S> queue) {
       while(!queue.isEmpty()) { queue.pop(); }
    }
    

    不是

    <S> public void emptyList(CyclicQueue<S> queue) {
        while(!queue.isEmpty()) { queue.pop(); }
    }
    

    模型答案将不起作用,因为您的修饰符 public、protected、private 的默认值优先于泛型类型。

    【讨论】:

    • 给你一个修饰符的顺序。这不是强制性的。该链接声称有“正确的顺序”是不正确的。
    • 同意。排序不是强制性的,但它是约定俗成的,更容易阅读。
    【解决方案2】:

    泛型类型不是修饰符,在泛型方法中应该放在返回类型之前,比如

    public <S> void emptyList(CyclicQueue<S> queue) {
    //         ^^^^ return type
        while(!queue.isEmpty()) { queue.pop(); }
    }
    

    您的问题的模型答案将无法编译。

    【讨论】:

      【解决方案3】:

      我不认为放在 access 关键字之前是合法的。换句话说,

      public <S> void emptyList(CyclicQueue<S> queue) {
          while(!queue.isEmpty()) { queue.pop(); }
      }
      

      是正确的。 Java 中的主要功能实际上回答了您的大部分问题 -

      public static void main(String[] args){
      

      在这里您可以看到正确的顺序:访问级别、静态、返回类型。添加泛型类型只是替换返回类型。

      【讨论】:

        猜你喜欢
        • 2018-09-02
        • 1970-01-01
        • 2020-05-06
        • 2013-07-29
        • 2012-03-08
        • 2014-09-02
        • 2021-08-25
        • 2015-05-02
        • 2015-11-07
        相关资源
        最近更新 更多