为了账号安全,请及时绑定邮箱和手机立即绑定

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

难度入门
时长 1小时20分
学习人数
综合评分9.67
759人评价 查看评价
9.9 内容实用
9.6 简洁易懂
9.5 逻辑清晰
  • 基本的数据类型,void 等关键词都有类类型 int.class;void.class
    查看全部
  • 在java语言中,静态成员和普通数据类型不是对象,类是java.lang.Class的事例对象!例:创建一个类叫A那么这个A类就是java.lang.Class的一个实例对象
    查看全部
    0 采集 收起 来源:Class类的使用

    2015-01-14

  • public class ClassDome_3 { public static void main(String[] args) { A a = new A(); Class<? extends A> c_1 = a.getClass(); try { Method method_1 = c_1.getMethod("print", String.class,String.class); Method method_2 = c_1.getMethod("print", int.class,int.class); Method method_3 = c_1.getMethod("print"); System.out.println("++++++++++++++++++++++++++++++++++++++++++++++++"); method_1.invoke(a, "hello","world"); System.out.println("++++++++++++++++++++++++++++++++++++++++++++++++"); method_2.invoke(a, 10,20); System.out.println("++++++++++++++++++++++++++++++++++++++++++++++++"); method_3.invoke(a); System.out.println("++++++++++++++++++++++++++++++++++++++++++++++++"); } catch (Exception e) { e.printStackTrace(); } } } class A { public void print(){ System.out.println("无参数方法............"); } public void print(String a, String b){ System.out.println(a + "," + b); } public void print(int a, int b){ System.out.println(a + b); } }
    查看全部
  • 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、要获取一个类的某个方法,需要先得到类类型 2、通过Class.getMethod(name,parameterTypes)获得public的该方法:如c.getMethod("print",new Class[]{int.class,int.class})或者参数写成int,int; ——> 来获取 public void print(int a,int b) 3、同样getDeclaredMethdo(name,paramterTypes)获得自己声明的该方法 二:方法的反射操作;就是用method对象进行方法调用;当然还是需要传参的 method.invoke(对象实例,参数列表) 2.1:invoke(user,new Object[]{10,20})倘若没有参数就可省略:invoke(user) 2.2:invoke(user,10,20)//直接传参
    查看全部
  • 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[]
    查看全部
  • Method method: method.getReturnType()//返回值类型的类类型 method.getParameterType()//参数列表的类类型
    查看全部
  • 1:基本的数据类型,void 等关键词都有类类型 int.class;void.class 2: public void printClass(Object obj){ //要获取类的信息;首先要获取类的类类型 Class c=obj.getClass();//传递的是哪个子类的对象,c就是该子类的类类型 ;getClass()是一个 native的方法;用java声明,使用JNI调用;C语言来实现的; /** getMethods()方法获取的是所有的public 函数;包括父类继承而来的 getDeclaredMethords()获取的是所有该类自己声明的方法,不问访问权限 */ Method[] ms=c.getMethods(); }
    查看全部
  • 动态加载类: 1、静态加载类,是编译时刻加载;动态加载类,是运行时刻加载 2、new创建对象:是静态加载类,在编译时刻就需要加载所有的【可能使用到的类】。有一个类有问题(如不存在),都不能通过编译,会报错。 3、Class.forName()通过动态加载类,可以用到一个类时,才进行加载。
    查看全部
  • 1:类是对象;是类 java.lang.Class的对象实例。有三种表示: 1.1:Class class1=User.class (任何一个类都有一个隐含的静态成员) 1.2:Class class2=new User().getClass()(通过对象实例的getClass()方法) 1.3:Class class3=Class.forName("chang.user"); class1=class2=class3是相等的;是类类型; 那么如何创建实例对象哪? class1 or class2 or class3 调用 newInstance()方法;需要强制类型转换
    查看全部
    0 采集 收起 来源:Class类的使用

    2018-03-22

  • @Java反射机制——Class类的使用 一、类是谁的对象:类是java.lang.Class类的实例对象 1、任何类都是Class类的实例对象 ,这个对象表示这个类的类类型(class type) 2、获得class实例有三种方法,例: Foo foo = new Foo(); · 通过类名 Class c1 = Foo.class 得到(说明每个类都有一个隐含的静态成员) · 通过类的实例 Class c2 = foo.getClass();得到 · 通过 Class c3 = Class.forName(Foo); 得到 3、使用类类型,可以创建类的实例:Foo foo = (Foo)c1.newInstance();//需要有无参数的构造方法
    查看全部
    0 采集 收起 来源:Class类的使用

    2015-01-10

  • 获得类类型: 1>example.class 2>example.getclass() 3>Class.forName("com.lx.Example") 类的实例化: 1>(Example)example.newInstance() [要有无参构造方法]
    查看全部
    0 采集 收起 来源:Class类的使用

    2018-03-22

  • 静态类不是对象 ,基本类型不是对象
    查看全部
    1 采集 收起 来源:Class类的使用

    2014-12-30

  • 只在编译阶段有效
    查看全部
  • @Java反射机制——通过反射了解集合泛型的本质 1、反射的操作都是【编译之后】的操作(因为编译获得class字节码文件之后才能得到.class),即运行时操作 2、所以method.invoke()方法也是运行期运行,可以绕过编译期。 二、验证:对一个带有泛型的数组添加不同于泛型的元素。 1、例如:List<String> list = new ArrayList<String>() 2、通过Method m = list.getClass().getMethod("add",Object.class);获得list.add()方法的对象 3、m.invoke(list,"hello");m.invoke(list,1); 按理因为泛型的存在,不能添加整形"1"进去。因为invoke()是运行期操作,所以能够通过编译。 4、结果显示,能够插入"hello"和1,说明<>泛型只作用于编译期,且只是为了规范输入
    查看全部

举报

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

微信扫码,参与3人拼团

意见反馈 帮助中心 APP下载
官方微信
友情提示:

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