java-基础-变长参数
2016-07-17 16:04
471 查看
在Java5 中提供了变长参数(varargs),也就是在方法定义中可以使用个数不确定的参数,对于同一方法可以使用不同个数的参数调用。
可变长参数的定义
在调用方法的时候,如果能够和固定参数的方法匹配,也能够与可变长参数的方法匹配,则选择固定参数的方法
如果要调用的方法可以和两个可变参数匹配,则出现错误
一个方法只能有一个可变长参数,并且这个可变长参数必须是该方法的最后一个参数
第一个能编译通过,这是为什么呢?事实上,base对象把子类对象sub做了向上转型,形参列表是由父类决定的,当然能通过。而看看子类直接调用的情况,这时编译器看到子类覆写了父类的print方法,因此肯定使用子类重新定义的print方法,尽管参数列表不匹配也不会跑到父类再去匹配下,因为找到了就不再找了,因此有了类型不匹配的错误。
这是个特例,覆写的方法参数列表竟然可以与父类不相同,这违背了覆写的定义,并且会引发莫名其妙的错误。
覆写必须满足的条件:
(1)重写方法不能缩小访问权限;
(2)参数列表必须与被重写方法相同(包括显示形式);
(3)返回类型必须与被重写方法的相同或是其子类;
(4)重写方法不能抛出新的异常,或者超过了父类范围的异常,但是可以抛出更少、更有限的异常,或者不抛出异常。
可变长参数的定义
print(String... args){ ... }
print(); print("hello"); print("hello","lisi"); print("hello","张三", "alexia")
在调用方法的时候,如果能够和固定参数的方法匹配,也能够与可变长参数的方法匹配,则选择固定参数的方法
import static java.lang.System.out; public class VarArgsTest { public void print(String... args) { for (int i = 0; i < args.length; i++) { out.println(args[i]); } } public void print(String test) { out.println("----------"); } public static void main(String[] args) { VarArgsTest test = new VarArgsTest(); test.print("hello"); test.print("hello", "alexia"); } }
如果要调用的方法可以和两个可变参数匹配,则出现错误
import static java.lang.System.out; public class VarArgsTest1 { public void print(String... args) { for (int i = 0; i < args.length; i++) { out.println(args[i]); } } public void print(String test,String...args ){ out.println("----------"); } public static void main(String[] args) { VarArgsTest1 test = new VarArgsTest1(); test.print("hello"); test.print("hello", "alexia"); } }
一个方法只能有一个可变长参数,并且这个可变长参数必须是该方法的最后一个参数
public class VarArgsTest2 { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub // 向上转型 Base base = new Sub(); base.print("hello"); // 不转型 Sub sub = new Sub(); sub.print("hello"); } } // 基类 class Base { void print(String... args) { System.out.println("Base......test"); } } // 子类,覆写父类方法 class Sub extends Base { @Override void print(String[] args) { System.out.println("Sub......test"); } }
第一个能编译通过,这是为什么呢?事实上,base对象把子类对象sub做了向上转型,形参列表是由父类决定的,当然能通过。而看看子类直接调用的情况,这时编译器看到子类覆写了父类的print方法,因此肯定使用子类重新定义的print方法,尽管参数列表不匹配也不会跑到父类再去匹配下,因为找到了就不再找了,因此有了类型不匹配的错误。
这是个特例,覆写的方法参数列表竟然可以与父类不相同,这违背了覆写的定义,并且会引发莫名其妙的错误。
覆写必须满足的条件:
(1)重写方法不能缩小访问权限;
(2)参数列表必须与被重写方法相同(包括显示形式);
(3)返回类型必须与被重写方法的相同或是其子类;
(4)重写方法不能抛出新的异常,或者超过了父类范围的异常,但是可以抛出更少、更有限的异常,或者不抛出异常。
public class VarArgsTest { public static void m1(String s, String... ss) { for (int i = 0; i < ss.length; i++) { System.out.println(ss[i]); } } public static void main(String[] args) { m1(""); m1("aaa"); m1("aaa", "bbb"); } }
b
相关文章推荐
- 源码分析-java-AbstractList-Itr和ListItr的实现
- pom.xml简介
- java判断文件的真实类型
- JAVA 面向对象 类和对象
- java并发之CAS
- Java的基础概念
- JAVA BigInteger
- java设计模式-克隆模式(复制模式)
- maven eclipse环境搭建
- 两个链表的第一个公共结点 java
- MyEclipse更改字体大小,导入导出工程,查看源码
- JAVA中ArrayList顺序容器
- Java软件工程师的基础知识点
- java-并发-线程安全
- 使用Eclipse这些快捷键,效率提升一倍
- java补习第三天
- J2EE基础之JavaBean
- eclipse中的快捷键
- 将eclipse项目导入到android studio心得体会
- java虚拟机知识整理——虚拟机的内存区域