String....可变参与和String[]的差距

首先这是jdk1.5之后的新特性,我们叫它为可变参数,即  varargs 。 之前我们定义可变参数是采用String[] args的方法来声明。jdk1.5之后有了更加简便的方式。
事实上String[] args 和 String... args 本质上不没有什么区别,String... args 最后还是转化成String[] args 来做的,只是String... args这种形式在应用上更加的灵活和简便。
例如有下面的两个方法:

public static void callMe1(String[] args) {  
  System.out.println(args.getClass() == String[].class);  
  for(String s : args) {  
    System.out.println(s);  
  }  
}  
    
public static void callMe2(String... args) {  
  System.out.println(args.getClass() == String[].class);  
  for(String s : args) {  
    System.out.println(s);  
  }  
}


他们可以这样子被调用:

callMe1(new String[] {"a", "b", "c"});  
callMe2("a", "b", "c");  
callMe2(new String[] {"a", "b", "c"});


但是不能

 
  
callMe1("a", "b", "c");


这就是String... args定义方法的灵活之处。并且当一个方法定义中有String... args形参时,实参传递的参数个数可以是少于最大个数的任意个,可以不传 参数。

但是这样子定义在方便的同时也是要付出一定的代价的,那就是String...args只能定义在形参的最后一个参数,而String[] args就没有这样的限制了。所以我们在定义的时候也就各取所需了。     

所以当有一天你发现这样子定义main函数不要以为是错的

public static void main(String... args) {

//do something

}
不过要声明的是:这种方法并不是官方推荐的方法,要尽量少用为妙,不然容易出现问题。

 
  

你可能感兴趣的:(Spring)