为了账号安全,请及时绑定邮箱和手机立即绑定
慕课网数字资源数据库体验端
反射——Java高级开发必须懂的_学习笔记_慕课网
为了账号安全,请及时绑定邮箱和手机立即绑定

反射——Java高级开发必须懂的

Cedar
难度入门
时长 1小时20分
  • Object类native JNI 技术
    查看全部
  • 导出方法
    查看全部
  • 为什么是true,没有想明白。 ArrayList list1=new ArrayList(); ArrayList<String> list2=new ArrayList<String>(); Class c1=list1.getClass(); Class c2=list2.getClass(); System.out.print(c1==c2);//true
    查看全部
  • Class类
    查看全部
  • 类。class class是隐藏的静态成员变量
    查看全部
    0 采集 收起 来源:Class类的使用

    2016-11-13

  • Java反射机制——通过反射了解集合泛型的本质 1:反射的操作都是编译之后的操作;就是运行阶段 2:java中集合的泛型是防止错误输入的;只在编译阶段有效,只要绕过编译就无效啦 我们可以通过方法的反射来操作,绕过编译 eg: ArrayList list1=new ArrayList(); ArrayList<String> list2=new ArrayList<String>(); Class c1=list1.getClass(); Class c2=list2.getClass(); System.out.print(c1==c2);//true Method m=c2.getMethod("add",Object.class); m.invoke(list2,20);//向list2集合中添加一个int 型的值,可以绕过编译,添加成功 但是不能直接foreach list2集合的,会报类型转换错误
    查看全部
  • 方法的反射: 1.获取A类中的print(int,int)方法: ①要获取一个方法就是获取类的信息,获取类的信息首先要获取类的类类型 A a1=new A(); Class c= a1.getClass(); ②获取方法 由名称和参数列表来决定,getMethod获取的是public方法,getDelcaredMethod获取自己声明的方法 Method m =c.getMethod(methodName,paramtypes);//paramtypes可以用数组的形式 表示new Class[]{int.class,int.class},也可以直接列举类类型 2.方法的反射操作:是用m对象来进行方法调用,和a1.print(10,20)调用的方法相同 m.invoke(a1,new Object[]{10,20}) Object o=m.invoke(对象名,参数);//方法如果没有返回值返回null,如果有返回值返回具体值,参数可用数组的方式表示,也可以直接列举,没有参数就不写 public Class A{ public void print(){}; public void Print(Sting a,String b){} public void Print(int a,int b){}; } public Class B{ public static void main(String[] args){ A a1 = new A(); Class c= a1.getclass; Method getMet=c.getMethod("print",String.class,String.class);//忘了加引号 Object obj=getMet.invoke(a1,"df","df"); } }
    查看全部
  • 只要在类里面声明的都有类类型 public static void pringClassMessage(Object object){ //要获取类的信息,首先要获取类的类型 Class c=object.getClass();//传递的是哪个子类的对象,c就是该子类的类类型 //获取类的名称 System.out.println("类的名称是:"+c.getName()); /* * Method类,方法对象 * 一个成员方法就是一个Method对象 * getMethods()方法获取的是所有public函数,包括父类继承而来的 * getDeclaredMethods()获取的是所有该类自己声明的方法,不问访问权限 * */ Method[] ms=c.getMethods();//c.getDeclaredMethods(); for (int
    查看全部
  • 1、静态加载类,是编译时刻加载;动态加载类,是运行时刻加载 2、new创建对象:是静态加载类,在编译时刻就需要加载所有的【可能使用到的类】。有一个类有问题(如不存在),都不能通过编译,会报错。 3、Class.forName()通过动态加载类,可以用到一个类时,才进行加载。 【功能性的类尽量使用动态加载,并对新添的类实现功能性接口(标准),这样就不用重新编译】 1.Clss.forName("类的全称") 不仅表示了类的类类型,还代表了动态加载类 请大家区分编译、运行 编译时刻加载类是静态加载类,运行时刻加载类是动态加载类 2.//new 创建对象是静态加载类,在编译时刻就需要加载所有的可能使用到的类。eg word excel //通过动态加载类可以解决该问题 //动态加载类,在运行时刻加载 Class c=Class.forName(args[0]); //通过类类型,创建该类对象 OfficeAble oa=(OfficeAble)c.newInstance();//word 和excel都想加载就用一个标准oa oa.start(); //编写一个标准接口 interface OfficeAble { public void start(); } //让word 和excel继承oa class Excel implements OfficeAble { public void start(){ } }
    查看全部
  • Java反射机制——通过反射了解集合泛型的本质**特别重要*** 1:反射的操作都是编译之后的操作,也就是运行时刻; 2:java中集合的泛型是防止错误输入的;只在编译阶段有效,只要绕过编译就无效啦 我们可以通过方法的反射来操作,绕过编译 eg: ArrayList list1=new ArrayList(); ArrayList<String> list2=new ArrayList<String>(); Class c1=list1.getClass(); Class c2=list2.getClass(); System.out.print(c1==c2);//true Method m=c2.getMethod("add",Object.class); m.invoke(list2,20);//向list2集合中添加一个int 型的值;绕过编译 这时就不能直接foreach list2集合的,会报类型转换错误
    查看全部
  • 方法的反射:****特别重要******* 1.获取A类中的print(int,int)方法: ①要获取一个方法就是获取类的信息,获取类的信息首先要获取类的类类型 A a1=new A(); Class c= a1.getClass(); ②获取方法 由名称和参数列表来决定,getMethod获取的是public方法,getDelcaredMethod获取自己声明的方法 Method m =c.getMethod(methodName,paramtypes);//paramtypes可以用数组的形式表示new Class[]{int.class,int.class},也可以直接列举类类型 2.方法的反射操作:是用m对象来进行方法调用,和a1.print(10,20)调用的方法相同m.invoke(a1,new Object[]{10,20}) Object o=m.invoke(对象名,参数);//方法如果没有返回值返回null,如果有返回值返回具体值,参数可用数组的方式表示,也可以直接列举,没有参数就不写
    查看全部
  • Java反射机制——获取成员变量&构造函数 一、成员变量是java.lang.reflect.Field的对象 1、Field类封装了关于成员变量的操作 2、Field[] fs = c.getFields()方法获取所有public的成员变量Field[]信息 3、c.getDeclaredFields获取的是该类自己声明的成员变量信息 4、field.getType()获得成员类型的类类型 5、field.getName()获得成员的名称 二、构造函数是java.lang.Constructor类的对象 1、通过Class.getConstructor()获得Constructor[]所有公有构造方法信息 2、建议getDeclaredConstructors()获取自己声明的构造方法 3、Constructor.getName():String 4、Constructor.getParameterTypes():Class[]
    查看全部
  • 挺好的,老师讲的,挺难得,
    查看全部
  • package com.imooc.reflect; import java.lang.reflect.Method; public class ClassUtil { /** * 打印类的信息,包括类的成员函数、成员变量 * @param obj */ public static void printClassMessage(Object obj){ //获取类的信息,首先要获取类的类类型 Class c=obj.getClass();//传递的是哪个子类的对象,c就是该子类的类类型 /*注释:getClass()是native声明的一个本地方法:java里面有一门技术JNI,专门由于制作本地方法,该方法用Java声明,C语言去实现,在Java里面去调用*/ System.out.println("类的全名:"+c.getName());//获取类的全名 /** * Method类,方法对象 * 一个成员方法就是一个Method对象 * getMethods()方法获取的是所有的public的函数,包括继承自父类的 * getDeclaredMethods()获取的是该类声明的所有方法,不论访问权限 */ Method[] methods=c.getMethods();//包含继承自父类的 for(int i=0;i<methods.length;i++){ Class returnType=methods[i].getReturnType();//方法的返回值类型的类类型 System.out.print(returnType.getName()+" "); System.out.print(methods[i].getName()+"(");//打印方法名 //获取参数类型 Class [] paramTypes=methods[i].getParameterTypes();//参数列表的类型的类类型 for(Class c1:paramTypes){ System.out.print(c1.getName()+","); } System.out.println(")"); } } }
    查看全部
  • ***这节的动态加载类很有意义の*** 1、Class.forName("类的全称");不仅表示该类的类类型,还代表了动态加载类; 2、需明确区分编译、运行 3、编译时刻加载类是静态加载类、运行时刻加载类是动态加载类; (1)new创建对象是静态加载类,在编译时刻就需要加载所有可能用到的类; (1)
    查看全部

举报

0/150
提交
取消
课程须知
童鞋们,学习本课程前需要熟悉Java面向对象的思想,并能掌握Java IO输入输出流、集合和泛型等知识。可参考慕课网Java入门的一、二、三季以及我的文件我做主——Java IO流课程。
老师告诉你能学到什么?
1、能够理解并应用反射机制。 2、能够了解反射机制在集合泛型中的应用。 3、有利于更好的学习框架等Java高级技术。
友情提示:

您好,此课程属于迁移课程,您已购买该课程,无需重复购买,感谢您对慕课网的支持!