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

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

Cedar
难度入门
时长 1小时20分
  • 确定某个方法
    查看全部
  • 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.方法的反射的好处就是解耦,比如说a,b,c对象都要调用 print()方法,正常的想法就是要创建每个对象,并且a.print() b.print() c.print() ,但是使用反射的话,就 print()方法的对象.invoke(a,参数列表)想要用哪个对象就用哪个对象
    查看全部
  • 方法的反射: 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"); } }
    查看全部
  • 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的对象;
    查看全部
  • 基本数据类型,void关键字都存在类类型 class.getMethods()方法获取是该类的所有public方法,包括从父类继承的方法; class.getDeclareMethods()方法获取该类自行声明的所有方法,不论访问权限; method.getName()获取方法名 method.getReturnType()获取方法的返回值 method.getParameterTypes(),获取方法的参数类型的类类型数组class[] 三获取方法信息: 一、基本的数据类型,void关键字等都存在类类型 Class c = 基类.class (int,String,double,void等) 二、Class类的基本API操作的 1、c.getName()可以获取类的名称 2、c.getSimpleName();//不包含包名的类的名称 3、c.getMethods()获取类的【public方法】集合,【包括继承来的】 ***注意【所有方法都是Method类的对象】 4、c.getDeclaredMethods()获取的是所有该类【自己声明】的方法,【不问访问权限】 三、Method类提供了一些操作方法的方法 1、.getReturnType()得到该方法的返回值类型的类类型(class),如int.class String.class 2、.getName()得到方法的名称 3、.getParameterTypes()获得参数列表类型的类类型,如参数为(int,int)则得到(int.class ,int class) Class c1 = int.class; int的类类型 Class c2 = String.class; String类的类类型 String类字节码 Class c3 = double.class; double这个数据类类型的字节码表示方式 Class c4 = Double.class; Double这个类的类类型字节码表示方式 Class c5 = void.class; 表达了void这个类的类类型 getName为这个类的类类型的具体名称 c1.getName ---> int c2.getName ---> java.lang.String 类的全称 c2.getSimpleName ---> String 不包含包名的类的名称
    查看全部
  • new 出来的都是静态加载类,编译时刻加载所有类,编译出错即报错 //动态加载类,运行时刻加载,能运行就不报错 Class c = Class.forName(args[0]); //Word w = (Word)c.newInstance(); //Excel e = (Excel)c.newInstance(); OfficeAble oa = (OfficeAble)c.newInstance();//OfficeAble定义的功能类型接口,Word和Excel都继承于它 oa.start();
    查看全部
  • 1.类也是对象,是java.lang.Class的实例对象 2.任何一个类都是Class类的实例对象,有三种表示方式: (Class的构造方法是私有的,只允许JVM调用,因此无法通过关键词new创建Class的实例对象) • 通过类名.class创建,也即说明任何一个类都有一个静态的成员变量class 如:Class c1 = Foo.class; • 通过类的对象的getClass方法 如:Foo foo1 = new Foo(); Class c2 = foo1.getClass(); • 通过Class的forName方法传入类的全限定名获取 如:Class c3 = null; c3 = Class.forName("com.imooc.reflect.Foo");(会有ClassNotFoundException) • c1、c2表示的Foo类的类类型(class type) 万事万物皆对象,类也是对象,是Class类的实例对象,这个对象称为类的类类型 可以通过类的类类型创建该类的对象 § 如:Foo foo2 = (Foo)c1.newInstance(); • 一个类只能是Class的一个实例对象,无论通过三种方法中的哪一种获取都一样 • 三种方法中,c1、c2为静态加载类(编译时加载),而c3为动态加载类(运行时加载)
    查看全部
    0 采集 收起 来源:Class类的使用

    2018-03-22

  • 。。。。
    查看全部
  • 类里面声明的都有类类型
    查看全部
  • 为什么使用newInstantce()创建新对象时,需要强制类型转换? 就是为什么OfficeAble oa = (OfficeAble) c.newInstance(); 而不是OfficeAble oa = c.newInstance(); public T newInstance() 查看API文档返回的是一个泛型的
    查看全部
  • 1、new 出来的都是静态加载类,一招出错,全盘皆输; 2、动态加载类 Class c = Class.forName(args[0]); OfficeAble oa = (OfficeAble)c.newInstance();//OfficeAble定义的功能类型接口
    查看全部
  • 所有的类 都是java.lang.Class 的对象 任何一个类都含有一个隐含的静态成员变量class c1=c2,一个类只可能是Class类的一个实例对象,单例模式?
    查看全部
    0 采集 收起 来源:Class类的使用

    2017-07-19

  • 1:Class class1=Foo.class; ------->实际在告诉我们,任何一个类都有一个隐含的静态成员变量 2: Class class2=foo1.getClass()---->已知该类的对象,通过该类的对象通过getClass方法 class1和class2表示Foo类的类 类型(class type) Foo这个类本身就是一个对象,Foo类的对象: 3:Class class3=null; class3=Class.forName(); class1==class2==class3
    查看全部
    0 采集 收起 来源:Class类的使用

    2018-03-22

  • Constructor
    查看全部

举报

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

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