-
功能性的类尽量使用动态加载而不使用静态加载查看全部
-
new创建对象是静态加载类,在编译时刻就需要加载所有的可能使用到的类。 使用Class.forName进行动态加载类,在运行时刻才会加载: Class c =Class.forName("Word"); 通过c.newInstance()来获实例,获得实例具体是哪个自行进行判断,可以通过接口来实现复用。查看全部
-
万事万物皆对象,类也是对象,是Class类的实例对象查看全部
-
method包查看全部
-
资料2查看全部
-
资料1查看全部
-
new创建对象是静态加载类,在编译时刻就需要加载所有可能使用到的类查看全部
-
类是java.lang.Class类的实例对象。 //三种表示方法,任何一个类都有一个隐含的静态成员变量class Class c1 = Foo.class; Class c2=fool.getClass(); Class c3 = Class.forName("com.imooc.foo"); //c1, c2都代表了Foo类的类类型,一个类只可能是Class类的一个对象 System.out.println(c1==c2);//true 可以通过类的类型来创建该类的对象。查看全部
-
类是对象,类是java.lang.Class类的实例对象查看全部
-
@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,说明<>泛型只作用于编译期,且只是为了规范输入查看全部
-
@Java反射机制——方法反射的基本操作 一、如何获取某个方法:方法的【名称】和【方法的参数列表】才能【唯一确定】某个方法 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、同样getDeclaredMethod(name,paramterTypes)获得自己声明的该方法 二、方法的反射操作:method.invoke(对象,参数列表); 1、方法反射:通过调用方法的对象invoke(【对象】,参数列表),来操作定义该方法的【对象】,实现该方法 2、获得方法的对象后,用对象method来进行方法调用Object o = method.invoke(c,new Object[]{10,20})也可以直接写10,20。若方没有返回值,则返回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[]查看全部
-
@Java反射机制——获取方法信息 一、基本的数据类型,void关键字等都存在类类型 Class c = 基类.class (int,String,double,void等) 二、Class类的基本API操作的 1、c.getName()可以获取类的名称 2、c.getSimpleName();//不包含包名的类的名称 3、c.getMethods()获取类的【public方法】集合,【包括继承来的】 4、c.getDeclaredMethods()获取的是所有该类【自己声明】的方法,【不问访问权限】 三、Method类提供了一些操作方法的方法 1、.getReturnType()得到该方法的返回值类型的类类型(class),如int.class String.class 2、.getName()得到方法的名称 3、.getParameterTypes()获得参数列表类型的类类型,如参数为(int,int)则得到(int.class ,int class)查看全部
-
@Java反射机制——动态加载类 1、静态加载类,是编译时刻加载;动态加载类,是运行时刻加载。 2、new创建对象:是静态加载类,在编译时刻就需要加载所有的【可能使用到的类】。有一个类有问题(如不存在),都不能通过编译,会报错。 3、Class.forName()通过动态加载类,可以用到一个类时,才进行加载。 【功能性的类尽量使用动态加载,并对新添的类实现功能性接口(标准),这样就不用重新编译】查看全部
-
@Java反射机制——Class类的使用 1.静态的成员,普通数据类型不是对象 2.类是java.land.Class类的实例对象 3.任何一个类都是Class的实例对象,有三种表达方式 (1)Class c1 = 类名.class; (2)Class c2 = 类的实例对象.getClass(); (3)Class c3 = Class.forName(类名); 其中c1,c2,c3都是一样的,即c1==c2.c1==c3,c2==c3;因为一个类只有一个类类型(class type) 4.通过类类型的newInstance()获取类的实例对象;前提是该类有空参数的构造方法。查看全部
举报
0/150
提交
取消