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

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

Cedar
难度入门
时长 1小时20分
  • 如何获取某个方法:方法的名称和方法的参数列表才能唯一决定某个方法,方法反射的操作,method.invoke(对象,参数列表) 方法的反射操作时用m对象来进行方法调用和a1.print调用的效果
    查看全部
  • 成员变量也是对象,是java,lang.reflect.Field的对象,Filed类封装了关于成员变量的操作,getFiled()方法获取的是虽有的public的成员变量的信息,getDeclaredFields获取的是该类自己声明的成员变量的信息。
    查看全部
  • 反射-泛型本质:反射操作是在运行时刻(编译之后);编译后集合就没有泛型了;泛型只在编译阶段有效,防止错误输入;通过方法反射操作,绕过编译。测试:Method m=c.getMethod("add",object.class);m.invoke(list对象,obj);(list.size();可以判断加入进去了)之后不能使用foreach遍历(因为内部参数数据类型不统一,会抛exception)。
    查看全部
  • 类是对象,类是java.lang.Class类的实例对象
    查看全部
    0 采集 收起 来源:Class类的使用

    2015-06-30

  • 本课程主要内容为Class类的使用,方法的反射,成员变量的反射,构造函数的反射,Java类加载机制
    查看全部
    0 采集 收起 来源:Class类的使用

    2015-06-30

  • 获取方法Method对象getMethod(name,p) c.getDeclaredMethod(name,param[]); Method 的invoke() 反射操作对象,返回值是方法的返回值 Object...args new Class[]{}空参==不写
    查看全部
  • 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集合的,会报类型转换错误
    查看全部
  • 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[] 成员变量也是对象,是java.lang.reflect.Field的对象; Field类封装了关于成员变量的操作;getFields()方法获取的是所有的public的成员变量的信息; getDeclaredFields获取的是该类自己声明的成员变量的信息; java/lang.Constructor中封装了构造函数的信息 getConstructors获取了酥皮的public的构造函数; getDeclaredConstructor得到所有的构造函数 获取类的信息,首先获取类的类类型 4.获取成员变量信息及成员函数信息 (1)获取成员变量信息 getFileds()-->打印所以public成员变量信息 getDeclaredFiled()-->打印自己声明的成员变量信息 (2)提取方法的工具: 右击-->Refactor(重构)-->ExtractMethod()导出方法 (3)样例 类1(静态方法,打印成员变量信息)--->类2(Main中测试)
    查看全部
  • 只要在类里面声明的都有类类型 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 i = 0; i < ms.length; i++) { //得到方法的返回值类型的类类型 Class returnType=ms[i].getReturnType(); System.out.println(returnType.getName()); //得到方法名 System.out.println(ms[i].getName()+"("); //获取参数类型-->得到的是参数列表的类型的类类型 Class[] paramType=ms[i].getParameterTypes(); for (Class class1: paramType) { System.out.println(class1.getName()+","); } System.out.println(")"); } } }
    查看全部
  • new 创建对象 是静态加载类,在编译时刻就需要加载所有的可能使用的类;<br><br> 通过动态加载类可以解决该问题<br><br> Class c = Class.forName(args[0]);<br><br> 通过类类型,创建该类对象。<br><br> //动态加载类,在运行时刻加载<br> Class c=Class.forName(args[0]);<br> //通过类类型,创建该类对象<br> OfficeAble oa=(OfficeAble)c.newInstance();//word 和excel都想加载就用一个标准oa<br> oa.start();<br> //编写一个标准接口<br> interface OfficeAble<br> {<br> public void start();<br> }<br> <br> //让word 和excel继承oa<br> class Excel implements OfficeAble<br> {<br> public void start(){<br> }<br> }<br> OfficeAble oa=(OfficeAble)c.newInstance();<br><br> oa.start();<br><br> <br><br> 定义个接口Interface OfficeAble,让子类实现它。<br><br> <br><br> 在线升级用的就是动态加载类。<br><br> 功能性的类,要使用动态加载,而不能使用静态加载。
    查看全部
  • 只有JVM能创建Class类的实例,它的构造方法是私有的。 任何一个类都是Class的实例对象,这个实例对象有三种表示方式。 第一种表示方式,告诉我们任何一个类都有一个隐含的静态成员变量class。 Class c1=Foo.class; 第二种表达方式,已经知道该类的对象通过getClass方法 Class c2=foo1.getClass(); 官网c1 c2表示了Foo类的类类型(class type), 万事万物皆对象,是Class类的实例对象 这个对象我们称为该类的类类型 c1==c2 一个类只可能是Class类的一个实例对象,所以以上相等。 第三种表达方式 Class c3 = null; c3=Class.forName("com.imooc.reflect.Foo"); c2==c3==c1 我们完全可以通过类的类类型创建该类的对象实例,即通过c1 c2 c3创建Foo的实例 Foo f=(Foo)c1.newInstance();//需要有无参数的构造方法
    查看全部
    0 采集 收起 来源:Class类的使用

    2018-03-22

  • 方法的反射 1)如何获取某个方法 2)方法反射的操作
    查看全部
  • Java反射机制——通过反射了解集合泛型的本质 1:反射的操作都是编译之后的操作;就是运行阶段 2:java中集合的泛型是防止错误输入的;只在编译阶段有效,只要绕过编译就无效啦 我们可以通过方法的反射来操作,绕过编译
    查看全部
  • 获取一个方法的步骤 1.获取类的类类型 2.获取方法,需要名称和参数列表 Class对象.getMethod(name, parameterType);//获取public方法 Class对象.getDeclaredMethod(name, parameterType);//获取该类本身的所有方法 方法的放射操作 用Method实例对象.invoke(被操作的对象,被操作的对象的函数的原本参数);
    查看全部
  • 方法的反射
    查看全部

举报

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

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