幸运飞艇彩神8app_Java反射的常见用法

  • 时间:
  • 浏览:1
  • 来源:熊猫辅助网_提供洋葱娱乐网技术_梅花辅助网资讯

    反射的常见用法有三类,第一类是“查看”,比如输入某个类的属性土方法等信息,第二类是“装载“,比如装载指定的类到内存里,第三类是“调用”,比如通过传入参数,调用指定的土方法。

1 查看属性的修饰符、类型和名字

    通过反射机制,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 能从.class文件里看一遍指定类的属性,比如属性的修饰符,属性和类型和属性的变量名。通过下面的ReflectionReadVar.java,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 看演示下具体的做法。    

1	import java.lang.reflect.Field;
2	import java.lang.reflect.Modifier;
3	class MyValClass{
4		private int val1;
5		public String val2;
6		final protected String val3 = "Java";

    亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 在第3行定义了有5个 多多MyValCalss的类,并在第4到第6行里,定义了有5个 多多属性变量。    

8	public class ReflectionReadVar {
9		public static void main(String[] args) {
10			Class<MyValClass> clazz = MyValClass.class;
11			//获取你你这人类的所有属性
12	        Field[] fields = clazz.getDeclaredFields();
13		    for(Field field : fields) {
14		    	   //输出修饰符	    	   System.out.print(Modifier.toString(field.getModifiers()) + "\t");
15		    	   //输出属性的类型
16		       System.out.print(field.getGenericType().toString() + "\t");
17		    	   //输出属性的名字
18		    	   System.out.println(field.getName());
19		      }
20		}
21	}

    在main函数的第10行里,通过MyValClass.class,得到了Class<MyValClass>类型的变量clazz,在你你这人变量中,存储了MyValClass你你这人类的或者 信息。

    在第12行里,通过了clazz.getDeclaredFields()土方法得到了MyValClass类里的所有属性的信息,并把什么属性的信息存入到Field数组类型的fields变量里。

    通过了第13行的for循环依次输出了什么属性信息。具体来讲,通过第14行的代码输出了该属性的修饰符,通过第16行的代码输出了该属性的类型,通过第18行的代码输出了该属性的变量名。这段代码的输出如下,从中亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 能看一遍各属性的信息。

          1      private    int val1

          2      public class java.lang.String   val2

          3      protected final   class java.lang.String   val3   

2 查看土方法的返回类型,参数和名字

    通过ReflectionReadFunc.java,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 能通过反射机制看一遍指定类的土方法。    

1	import java.lang.reflect.Constructor;
2	import java.lang.reflect.Method;
3	class MyFuncClass{
4		public MyFuncClass(){}
5		public MyFuncClass(int i){}
6		private void f1(){}
7		protected int f2(int i){return 0;}
8		public String f2(String s) {return "Java";}

    在第3行定义的MyFuncClass你你这人类里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 定义了有5个 多多构造函数和5个土方法。 

10	public class ReflectionReadFunc {
11		public static void main(String[] args) {
12			Class<MyFuncClass> clazz = MyFuncClass.class;
13	        Method[] methods = clazz.getDeclaredMethods();
14	        for (Method method : methods) 
15	        { System.out.println(method); }
16	        //得到所有的构造函数
17	        Constructor[] c1 = clazz.getDeclaredConstructors();
18	        //输出所有的构造函数
19	        for(Constructor ct : c1)
20	        { System.out.println(ct);  }
21		}
22	}

    在main函数的第12行,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 同样是通过了类名.class的土方法(也要是MyFuncClass.class的土方法)得到了Class<MyFuncClass>类型的clazz对象。

    在第13行里,是通过了getDeclaredMethods土方法得到了MyFuncClass类的所有土方法,并在第14行的for循环里输出了各土方法。在第17行里,是通过了getDeclaredConstructors土方法得到了所有的构造函数,并通过第19行的循环输出。

    本代码的输出结果如下所示,其中第1到第3行输出的是类的土方法,第4和第5行输出的是类的构造函数。    

1	private void MyFuncClass.f1()
2	protected int MyFuncClass.f2(int)
3	public java.lang.String MyFuncClass.f2(java.lang.String)
4	public MyFuncClass()
5	public MyFuncClass(int)

    不过在实际的项目里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 一般无需仅仅“查看”类的属性和土方法,在更多的情况里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 是通过反射装载和调用类里的土方法。

3 通过forName和newInstance土方法加载类

    在前文JDBC操作数据库的代码里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 看一遍在创建数据库连接对象(Connection)以后,时要通过Class.forName("com.mysql.jdbc.Driver");的代码来装载数据库(这里是MySQL)的驱动。

    能只有说,Class类的forName土方法最常见的用法要是装载数据库的驱动,以至于不少人会错误地认为你你这人土方法的作用是“装载类”。

    真是forName土方法的作用仅仅是返回有5个 多多Class类型的对象,它一般会和newInstance土方法配套使用,而newInstance土方法的作用才是加载类。

    通过下面的ForClassDemo.java这段代码,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 来看下综合使用forName和newInstance这有5个 多多土方法加载对象的土方法。    

1	class MyClass{
2		public void print()
3		{	System.out.println("Java");	}
4	}
5	public class ForClassDemo {
6		public static void main(String[] args)	{
7	        //通过new创建类和使用类的土方法
8			MyClass myClassObj = new MyClass();
9			myClassObj.print();//输出是Java
10			//通过forName和newInstance加载类的土方法	
11			try {
12				Class<?> clazz = Class.forName("MyClass");
13				MyClass myClass = (MyClass)clazz.newInstance();
14				myClass.print();//输出是Java
15			} catch (ClassNotFoundException e) {
16				e.printStackTrace();
17			} catch (InstantiationException e) {
18				e.printStackTrace();
19			} catch (IllegalAccessException e) {
20				e.printStackTrace();
21			}		
22		}
23	}

    在第1行定义的MyClass你你这人类里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 在其中的第2行定义了有5个 多多print土方法。

    Main函数的第8和第9行里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 演示了通过常规new的土方法创建和使用类的土方法,通过第9行,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 能输出“Java”你你这人字符串。

    在第12行,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 通过Class.forName("MyClass")土方法返回了有5个 多多Class类型的对象,请注意,forName土方法的作用都是“加载MyClass类”,要是返回有5个 多多所含MyClass信息的Class类型的对象。这里亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 是通过第13行的newInstance土方法,加载了有5个 多多MyClass类型的对象,并在第14行调用了其中的print土方法。

    既然forName土方法的作用仅仅是“返回Class类型的对象”,这么 在JDBC累积的代码里,为什么么么在亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 能通过Class.forName("com.mysql.jdbc.Driver");代码来装载MySQL的驱动呢?在MySQL的com.mysql.jdbc.Driver驱动类所含如下的一段静态初始化代码。   

1	static {
2	try {
3	   java.sql.DriverManager.registerDriver(new Driver());
4	} catch (SQLException e) {
5	throw new RuntimeException(“Can’t register driver!”);
6	}
7	}

    也要是说,当亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 调用Class.forName土方法后,会通过执行这段代码会新建有5个 多多Driver的对象,并调用第3行的DriverManager.registerDriver把刚创建的Driver对象注册到DriverManager里。

    在上述的代码里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 看一遍了除了new之外,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 还能通过newInstance来创建对象。

    真是这里说“创建”无须准确,真是说通过new和newInstance亲戚亲戚当我们当我们当我们 歌词 当我们当我们当我们 当我们当我们当我们 能得到有5个 多多可用的对象,但newInstance的作用真是是通过Java虚拟机的类加载机制把指定的类加载到内存里。

    亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 在工厂模式中,总是会通过newInstance土方法来加载类,但你你这人土方法只有是通过调用类的无参构造函数来加载类,机会亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 在创建对象时时要传入参数,这么 就得使用new来调用对应的带参的构造函数了。

4 通过反射机制调用类的土方法

    机会亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 通过反射机制来调用类的土方法,这么 就得除理有5个 多多问題,第一,通过什么土方法来调?第二,怎样传入参数,第三,怎样得到返回结果?

    通过下面的CallFuncDemo.java代码,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 将通过反射来调用类里的土方法,在其中亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 能看下上述有5个 多多问題的除理土方法。    

1	import java.lang.reflect.Constructor;
2	import java.lang.reflect.InvocationTargetException;
3	import java.lang.reflect.Method;
4	class Person {
5		private String name;
6		public Person(String name) 
7	    {this.name = name;}
8		public void saySkill(String skill) {
9		  System.out.println("Name is:"+name+",skill is:" + skill);
10		}
11		public int addSalary(int current) 
12	    {	return current + 100;}
13	}

    在第4行里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 定义了有5个 多多Person类,在其中的第6行里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 定义了有5个 多多带参的构造函数,在第8行里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 定义了有5个 多多带参但无返回值得saySkill土方法,在第11行里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 定义了有5个 多多带参或者返回int类型的addSalary土方法。    

14	public class CallFuncDemo {
15		public static void main(String[] args) {
16			Class c1azz = null;
17			Constructor c = null;
18			try {
19				c1azz = Class.forName("Person");
20				c = c1azz.getDeclaredConstructor(String.class);
21				Person p = (Person)c.newInstance("Peter");
22				//output: Name is:Peter, skill is:java
23				p.saySkill("Java");
24				// 调用土方法,时要传递对象实例,同時

传递参数值
25				Method method1 = c1azz.getMethod("saySkill", String.class);
26				//机会没返回值,什么都能直接调
27				//输出结果是Name is:Peter, skill is:C#
28	            method1.invoke(p, "C#");             
29	            Method method2 = c1azz.getMethod("addSalary", int.class);
100	            Object invoke = method2.invoke(p, 100);
31	            //输出100
32				System.out.println(invoke);
33			} catch (ClassNotFoundException e) {
34				e.printStackTrace();
35			} catch (NoSuchMethodException e1) {
36				e1.printStackTrace();
37			} catch (InstantiationException e) {
38				e.printStackTrace();
39			} catch (IllegalAccessException e) {
40				e.printStackTrace();
41			} catch (InvocationTargetException e) {
42				e.printStackTrace();
43			}
44		}
45	}

    在第19行里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 通过Class.forName得到了有5个 多多Class类型的对象,其中所含了Person类的信息。在第20行里,通过传入String.class参数,得到了Person类的带参的构造函数,并通过了第21行的newInstance土方法,通过你你这人带参的构造函数创建了有5个 多多Person类型的对象。以后在第23行里调用了saySkill土方法。这里亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 演示通过反射调用类的构造函数来创建对象的土方法。

    在第25行里,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 通过了getMethod土方法,得到了带参的saySkill土方法的Method类型的对象,以后通过第28行的invoke土方法调用了你你这人saySkill土方法,这里第有5个 多多参数是由哪个对象来调用,通过第5个参数,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 传入了saySkill土方法的String类型的参数。

    用同样的土方法,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 在第29和100行通过反射调用了Person类的addSalary土方法,机会你你这人土方法有返回值,什么都亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 在100行用了有5个 多多Object类型的invoke对象来接收返回值,通过第32行的打印一段话,亲戚亲戚当我们当我们当我们 当我们当我们当我们 当我们当我们当我们 能看一遍100你你这人执行结果。

猜你喜欢

1.5分pk10app赚钱 _【图文】林志颖想偷吃老婆月子餐 帽子深藏爱意成亮点

来源: 凤凰网 2015-12-11.5分pk10app赚钱 611:52:06   原文标题:【图文】林志颖想偷吃女

2020-06-02

分分飞艇app安卓_秋天凉了,多肉植物怎么养?

对于植物来说一年之计在于春而多肉之计则是春秋两季好不容易熬过了地狱般的夏季秋天又该为肉肉们做些那此呢?翻盆 秋天的工作非常多:翻盆、叶插、扦插、分分飞艇app安卓适当地调整肉肉

2020-06-02

10分时时彩安全吗_ 网络流行语:天生我笨必有用

【生活百科网】 首页生活小10分时时彩安全吗常识生活小窍门健康小常识健康饮食养生保健小偏方低碳生活运动健身急救常识热门搜索:健康常识问答一10分时时彩安全

2020-06-02

1分pk10技巧稳赚方法 _比达:母婴中高端市场持续增长 宝宝树孕育和亲宝宝月活用户领先

伴随1分pk10技巧稳赚方法 母1分pk10技巧稳赚方法 婴市场进入成熟期期期期图片 图片 的句子,中国母婴市场发展步入新阶段,其中电商领域发展放缓,中高端市场持续增长。比达

2020-06-02

分分飞艇手机版ios_ 春季喝点醋 轻松排毒素

冬季胡吃海喝,体内积累了不少毒素,春季草木生发,要排除体内淤积的毒素不妨喝或分分飞艇手机版ios多或少醋,在春天或多或少或多或少 都能否喝它,帮你排毒是一件非常非常轻松的事情

2020-06-02