Java中的方法修饰符排序[重复]
Posted
技术标签:
【中文标题】Java中的方法修饰符排序[重复]【英文标题】:Method modifier ordering in Java [duplicate] 【发布时间】:2013-06-11 02:26:15 【问题描述】:据我了解,这是定义典型方法的方式:
modifier returnValueType methodName(list of parameters)
// Method body;
但是,如果您有多个修饰符(例如public
、static
、<GenericType>
),它们应该有特定的顺序吗?
这是我过去考试问题之一的典型答案:
<S> public void emptyList(CyclicQueue<S> queue)
while(!queue.isEmpty()) queue.pop();
您可以看到通用修饰符 <S>
出现在 public
之前,但我在某些地方看到了这种情况:
public <S> void emptyList(CyclicQueue<S> queue)
while(!queue.isEmpty()) queue.pop();
这些修饰符的排序方式是正确的还是更传统的方式?
【问题讨论】:
【参考方案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)
在这里您可以看到正确的顺序:访问级别、静态、返回类型。添加泛型类型只是替换返回类型。
【讨论】:
以上是关于Java中的方法修饰符排序[重复]的主要内容,如果未能解决你的问题,请参考以下文章