反射机制学习总结:
1、编程语言的分类:
动态语言:在程序运行时动态的改变变量的类型,为变量增加,删除属性及方法。
例:
var a=4;
a=“hello world”;
a=new Object();
非动态语言:java不是动态语言;
2、反射机制:
java反射机制是java实现动态语言的关键;java可以通过反射技术实现动态语言的部分特征。这个机制允许程序在运行时透过Reflection APIs取得任何一个已知名称的class的内部信息
3、什么是反射技术:在程序运行时,动态分析类的能力就是反射。
Java反射机制容许程序在运行时加载、探知、使用编译期间完全未知的classes。
Java可以加载一个运行时才得知名称的class,获得其完整结构。
4、Class类:
java中没个class都有相应的一个Class对象
Class这个类代表加载到java虚拟机中的类的实例,每个类只加载一次,每个类只由唯一的一个类实例。
5、获取类实例的方式:
(1)利用对象调用自己的getClass()方法获取Class对象
Book book=new Book();
Class c=book.getClass();
(2)利用Class类的静态方法:
Class c=Class.forName(“类名”):
(3)运用.class的方式来获取Class实例
Class c=类名.class;
6、 在运行期间,如果我们要产生某个类的对象,Java虚拟机(JVM)会检查该类型的Class对象是否已被加载。如果没有被加载,JVM会根据类的名称找到.class文件并加载它。一旦某个类型的Class对象已被加载到内存,就可以用它来产生该类型的所有对象。
7、Class中常用的方法:
getName();获得类的全名,包括包名。
getSimpleName();返回底层类的简称(只获得类名)
getSuperClass();获得父类
getInterfaces();获得该类实现的接口
isXXX();判断是否为某种类型的实例(Array,Enum,Interface)
getComponentType();如果类实例是数组,得到数组中元素的类型。
int getModifiers();返回此类或接口以整数编码的 Java 语言修饰符。
(Modifier.toString(int ),根据整数编码获得修饰符的名称, Modifier中的方法全为静态)
8、java将数组作为一个类处理。
9、Field类:
Field提供有关类或接口的单个字段的信息,以及对它的动态访问权限。
(属性的元数据的封装)
获得Field的方法:
Class c=book.getClass();
Field [] fs= c.getFields();获得所有公共的属性(自定义和继承的)
Field f=c.getField(String name);根据属性名来获得指定的公共属性
Field [] fs=c.getDeclaredFields();获得所有自定义的属性
Field f=c.getDeclaredField(String name)根据属性名获得自定义的属性。
10、Field的方法:
getName(); 返回此 Field 对象表示的字段的名称。
getType();返回一个 Class 对象,它标识了此 Field 对象所表示字段的声明类型。
11、获得父类的私有的属性;
11、通过反射访问私有属性:
12、利用反射机制生成SQL语句(方法传一个随意类型的vo):
import java.lang.reflect.Field;
import java.sql.SQLException;
import com.jdbc.JdbcUtil;
public class CommonDao {
public String insert(Object obj) {
Class c=obj.getClass();
StringBuffer sql=new StringBuffer ("insert into "+c.getSimpleName()+"(");
StringBuffer values=new StringBuffer("values(");
Field []fs=c.getDeclaredFields();
for(int i=0;i<fs.length;i++) {
if(i==fs.length-1) {
sql.append(fs[i].getName()+")");
values.append("?)");
}else {
sql.append(fs[i].getName()+",");
values.append("?,");
}
}
sql.append(values);
String sql1=null;
sql1=sql.toString();
return sql1;
}
}