**
* Created by Lenovo on 2017/12/10.
* java中可变长参数
*/
public class reflect04 { //m1有一个int类型的可比变长参数
//m1在调用的时候实参可以是0-N个
public static void m1(int... a){
System.out.println("int型可变长参数执行...."+a);
} //如果有可以精确匹配的方法则调用该方法,不会再执行可变长参数的那个方法
public static void m1(int a){
System.out.println("精确匹配执行....."+a);
} //可变长参数可以等同看做一个数组
public static void m2(String... args){
for(int i=0;i<args.length;i++){
System.out.println("m2都喜欢的运动如下:"+args[i]);
}
} public static void m3(Class... args) throws Exception{ for(int i=0;i<args.length;i++){
Class arg = args[i];
System.out.println(arg.newInstance());
}
} //可变长参数只能出现一次,并且只能出现在所有参数的最后一位
//错误实例:
//public static void m4(String... args,int i){}
public static void main(String[] args) throws Exception { //执行m1
m1(1); //调用精确匹配的m1方法
m1(1,2);
m1(1,2,3);
m1(1,2,3,4); //执行m2
m2("旅游","看电影","游泳","打球"); //执行m3
m3(Date.class,Employlee.class); //m1输出
//m1精确输出:精确匹配执行.....1
//int型可变长参数执行....[I@330bedb4
//int型可变长参数执行....[I@2503dbd3
//int型可变长参数执行....[I@4b67cf4d //m2输出
//m2都喜欢的运动如下:旅游
//m2都喜欢的运动如下:看电影
//m2都喜欢的运动如下:游泳
//m2都喜欢的运动如下:打球 //m3输出
//Sun Dec 10 21:59:58 CST 2017
//空参构造方法执行.....
//Employlee{name='null'}
}
}
相关文章
- Java中string对象和数组对象作为参数传递给函数时候是值传递,而其他对象是引用传递。
- Java 实体类中对字段添加非空注解判断传入的参数是否为空
- java变长参数_Java可变长度参数
- java中优雅的参数校验方法
- C#委托(delegate)的常用方式- 委托的定义 // 委托的核心是跟委托的函数结构一样 public delegate string SayHello(string c); public delegate string SayHello(string c);:定义了一个公共委托类型 SayHello,该委托接受一个 string 类型的参数 c,并返回一个 string 类型的值。 Main 方法 static void Main(string args) { // 本质上其实就是把方法当作委托的参数 SayHello sayC = new SayHello(SayChinese); Console.WriteLine(sayC("欢迎大家")); SayHello sayE = new SayHello(SayEgnlish); Console.WriteLine(sayE("Welcome to")); // 简单的写法:必须类型一样 SayHello s1 = SayChinese; SayHello s2 = SayEgnlish; Console.WriteLine(s1("好好好")); Console.WriteLine(s2("Gooood")); // 最推荐 SayHello ss1 = con => con; Console.WriteLine(ss1("niiiice")); // 匿名委托:一次性委托 SayHello ss3 = delegate(string s) { return s; }; Console.WriteLine(ss3("说中国话")); } 常规实例化委托 SayHello sayC = new SayHello(SayChinese);:创建了一个 SayHello 委托的实例 sayC,并将 SayChinese 方法作为参数传递给委托的构造函数。 Console.WriteLine(sayC("欢迎大家"));:通过委托实例调用 SayChinese 方法,并输出结果。 同理,SayHello sayE = new SayHello(SayEgnlish); 和 Console.WriteLine(sayE("Welcome to")); 是对 SayEgnlish 方法的委托调用。 简化的委托赋值方式 SayHello s1 = SayChinese; 和 SayHello s2 = SayEgnlish;:当委托类型和方法签名一致时,可以直接将方法赋值给委托变量,无需使用 new 关键字。 Console.WriteLine(s1("好好好")); 和 Console.WriteLine(s2("Gooood"));:通过委托实例调用相应的方法。 使用 Lambda 表达式实例化委托 SayHello ss1 = con => con;:使用 Lambda 表达式创建委托实例 ss1,con => con 表示接受一个参数 con 并返回该参数本身。 Console.WriteLine(ss1("niiiice"));:通过委托实例调用 Lambda 表达式。 匿名委托 SayHello ss3 = delegate(string s) { return s; };:使用匿名委托创建委托实例 ss3,delegate(string s) { return s; } 是一个匿名方法,直接在委托实例化时定义了方法体。 Console.WriteLine(ss3("说中国话"));:通过委托实例调用匿名方法。 委托引用的方法定义 public static string SayChinese(string content) { return content; } public static string SayEgnlish(string content) { return content; } public static string SayChinese(string content) 和 public static string SayEgnlish(string content):定义了两个静态方法,分别接受一个 string 类型的参数 content,并返回该参数本身。这两个方法的签名与 SayHello 委托一致,可以被 SayHello 委托引用。 常规的委托实例化、简化的赋值方式、Lambda 表达式和匿名委托。委托在 C# 中是一种强大的机制,它允许将方法作为参数传递,实现了代码的灵活性和可扩展性。
- java中main函数的参数
- Java算法:反射实现map自动封装进实体类中 理解springmvc 参数封装底层原理
- java中的可释放资源定义,类似c#中的using
- java addmonth_Calendar的add方法中的DAY_OF_MONTH参数和DAY_OF_YEAR参数有什么区别?
- Java中的参数列表