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

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

Cedar
难度入门
时长 1小时20分
  • Class类 1)在面向对象的世界里,万事万物皆对象。 类是对象,类是java.lang.Class类的实例对象。 There is a class named Class 2)//Foo的实例对象如何表示 Foo foo1=new Foo();//foo1就表示出来了 //Foo这个类也是一个实例对象,Class类的实例对象,如何表示呢? //任何一个类都是Class的实例对象,这个实例对象有三种表示方式 //第一种表示方式--->实际在告诉我们任何一个类都有一个隐含的静态成员变量class Class c1=Foo.class; //第二种表达方式--->已经知道该类的对象通过getClassF方法 Class c2=foo1.getClass(); //官网c1,c2表示了Foo类的类类型(class type),万事万物皆对象,类也是对象,是Class类的实例对象 //这个对象我们称为该类的类类型 //不管c1 or c2都代表了Foo类的类类型,一个类只可能是Class类的一个实例对象 //第三种表达方式 Class c3=null; c3=Class.forName("com.imooc.reflect.Foo"); //我们完全可以通过类的类类型创建类的对象实例--->通过c1 or c2 or c3创建Foo的实例对象 Foo foo=(Foo)c1.newInstance();//需要有无参数的构造方法
    查看全部
    20 采集 收起 来源:Class类的使用

    2018-03-22

  • Java-Reflect专题 1.Class类的使用 2.方法的反射 3.成员变量的反射 4.构造函数的反射 5.Java类加载机制
    查看全部
    0 采集 收起 来源:Class类的使用

    2015-08-06

  • 反射的操作都是在编译之后的操作。 编译之后集合的泛型是去泛型化的。 java中集合的泛型,是防止错误输入的,只在编译阶段有效,绕过编译就无效了。 验证:可以通过方法的反射来操作,绕过编译。
    查看全部
  • 获取类名和类的方法
    查看全部
  • new创建对象,是静态加载类,在编译时刻就需要加载所有的可能使用到的类。可能出现编译时错误; 通过动态加载类可解决该问题。不会出现编译错误,只可能发生运行时错误。 动态加载类,在运行时加载。动态加载类可实现接口,继承接口特性,这样方便维护,实现更新补丁等功能。 class OfficeBetter{ public static void main(String[] args)throws Exception{ Class c = Class.forName(args[0]); OfficeAble oa = (OfficeAble)c.newInstance(); //通过类类型,创建该对象 //try-catch捕捉异常 oa.start(); } } Interface OfficeAble{// 接口,作为Word和Excel的结构 public void start(); //抽象方法 } class Excel implements OfficeAble{ public void start(){ System.out.println("Excel...start..."); } } class Excel implements OfficeAble{ public void start(){ System.out.println("Excel...start..."); } } Word类--编译时刻(此时Excel类没创建):javac Word.java javac OfficeBetter.java //不需要重新编译javac Office.java java OfficeBetter Word //运行结果:word...start... Excel类编译,同上。
    查看全部
  • 动态加载类: class.forName("类的全称") 不仅表示了类的类类型,还代表了动态加载类。 区分编译和运行。 编译时刻加载类是静态加载类,运行时刻加载类是动态加载类。 new创建对象,是静态加载类,在编译时刻就需要加载所有的可能使用到的类。
    查看全部
  • Class类 1.普通数据类型和静态的东西不是面向对象的。 2.类是对象,类是java.lang.Class类的实例对象。不能new出来。Class类的构造函数是私有的,只有java虚拟机可以用构造方法创建Class的实力对象。 有三种表示方式: a. Class c1 = Foo.class; //任何一个类都有一个隐含的静态成员变量class b. Foo foo1 = new Foo(); Class c2 = foo1.getClass(); //已经知道该类的对象通过getClass方法 /*官网c1 c2表示了Foo类的类类型(class type) c1 == c2*/ c. Class c3 = null; c3 = Class.forName("com.imooc.reflect.Foo"); //c3 == c1 == c2 可以通过类的类类型创建该类的对象实例 Foo foo = (Foo)c1.newInstance();//需要有无参数的构造方法
    查看全部
    0 采集 收起 来源:Class类的使用

    2018-03-22

  • 1. 普通数据类型 和 静态的东西都不是对象 。静态的东西是属于一个类。 2. 类是Class类的对象,所有类都是Class类的实例对象,但是不能new出来,因为Class类的构造方法是私有的,只有java虚拟机可以用构造方法创建CLass的实例对象。 表达某个类(Foo)是Class类的实例对象的方法: 第一种: Class c1=Foo.class; //任何一个类都有一个隐含的静态成员变量class 第二种: Class c2=foo.getClass(); //已知该类Foo的对象foo,通过实例对象foo的getCLass方法获取Class类的实例对象Foo 第三种: Class c3=Class.forName("package地址.Foo"); c1,c2,c3是Foo类的类类型,一个类只可能是Class类的一个实例对象,所以c1=c2=c3. 可以通过类的类类型创建该类的对象实例,即通过c1 c2 c3创建Foo的实例 Foo f=(Foo)c1.newInstance();//需要有无参数的构造方法
    查看全部
    0 采集 收起 来源:Class类的使用

    2018-03-22

  • new创建对象,是静态加载类,在编译时刻就需要加载所有的可能使用到的类。可能出现编译时错误; 通过动态加载类可解决该问题。不会出现编译错误,只可能发生运行时错误。 动态加载类,在运行时加载。动态加载类可实现接口,继承接口特性,这样方便维护,实现更新补丁等功能。 class OfficeBetter{ public static void main(String[] args)throws Exception{ Class c = Class.forName(args[0]); OfficeAble oa = (OfficeAble)c.newInstance(); //通过类类型,创建该对象 //try-catch捕捉异常 oa.start(); } } Interface OfficeAble{// 接口,作为Word和Excel的结构 public void start(); //抽象方法 } class Excel implements OfficeAble{ public void start(){ System.out.println("Excel...start..."); } } class Excel implements OfficeAble{ public void start(){ System.out.println("Excel...start..."); } } Word类--编译时刻(此时Excel类没创建):javac Word.java javac OfficeBetter.java //不需要重新编译javac Office.java java OfficeBetter Word //运行结果:word...start... Excel类编译,同上。
    查看全部
  • 1. 普通数据类型 和 静态的东西都不是对象 。静态的东西是属于一个类。 2. 类是Class类的对象,所有类都是Class类的实例对象,但是不能new出来,因为Class类的构造方法是私有的,只有java虚拟机可以用构造方法创建CLass的实例对象。 表达某个类(Foo)是Class类的实例对象的方法: 第一种: Class c1=Foo.class; //任何一个类都有一个隐含的静态成员变量class 第二种: Class c2=foo.getClass(); //已知该类Foo的对象foo,通过实例对象foo的getCLass方法获取Class类的实例对象Foo 第三种: Class c3=Class.forName("package地址.Foo"); c1,c2,c3是Foo类的类类型,一个类只可能是Class类的一个实例对象,所以c1=c2=c3. 可以通过类的类类型创建该类的对象实例,即通过c1 c2 c3创建Foo的实例 Foo f=(Foo)c1.newInstance();//需要有无参数的构造方法
    查看全部
    1 采集 收起 来源:Class类的使用

    2018-03-22

  • 反射的升华操作 泛型 通过class,method了解泛型的本质 编译之后集合的泛型是去泛型化的 java中集合的泛型,是防止错误输入的,只在编译阶段有效,绕过编译无效 验证:通过方法的反射来操作,绕过编译 method m = c1.getmethod("方法名",object.class); m.invoke(list1,100); //绕过编译操作,绕过了泛型 system.out.println(list1.size());
    查看全部
  • 一、如何获取某个方法:方法的【名称】和【方法的参数列表】才能【唯一确定】某个方法 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)//直接传参
    查看全部
  • 方法的反射: 1.如何获取某个方法 方法的名称和方法的参数列表才能唯一决定某个方法 2.方法反射的操作 method.invoke(对象,参数列表)
    查看全部
  • 成员变量也是对象 java.lang.reflact.field field类封装了关于成员变量的操作 getfield()方法获取所有的public的成员变量信息 field[] fs = c.getfield(); field[] fs = c.getdeclarefield(); classutil.printfieldmessage();获取打印信息 printconmessage(object obj) //打印对象的构造函数的信息 class c = obj.getclass(); 构造函数也是对象 java.lang.constructor中封装了构造函数的信息 getconstructors获取所有的public的构造函数 getdeclaredconstructors得到所有的构造函数 class[] paramtypes = constructor.getpatametertypes()
    查看全部
  • 只要在类里面声明的都有类类型 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(")"); } } }
    查看全部

举报

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

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