反射
1、创建反射类型(3种)
Class clazz1 = 类名.class;
Class clazz2 = Class.forName(“包名.文件名”);)(注:即类包的地址)
Class clazz3 = new 类名().getClass();
例:
Class clazz1 = Pet2.class;
Class clazz2 = clazz1.forName(“Fanshe.Pet2”);
Class clazz3 = new Pet2().getClass();
2、获取内容——属性
getModifiers():文件的修饰符类型,其中public对应1 ,private对应2;
getName():属性名字
getType():属性类型
getType().getName():属性类型的名字
例:单个属性:
field field = clazz1.getfield("psex");
System.out.println(field.getName());
System.out.println(field.getType());
System.out.println(field.getType().getName());
System.out.println(field.getModifiers());
注:
field field = clazz1.getfield(“psex”);
Field field = clazz1.getDeclaredField(“pname”);
getfield():只能是公有性的属性;
getDeclaredField():公有私有都可以;
一个类里的全部属性:
Field[] fields = clazz1.getFields();//一个类里的全部公有性的属性
for(Field field:fields){
System.out.println(field.getName());
System.out.println(field.getType());
System.out.println(field.getType().getName());
System.out.println(field.getModifiers());
}
若为:Field[] fields = clazz2.getDeclaredFields();
则是一个类里的全部属性
3、获取内容——方法:getMethod(“方法名”,参数类型)
getReturnType():返回值类型;
getSimpleName():最简化名字;
例:
①
Method method=clazz2.getDeclaredMethod("asd",String.class,int.class);
System.out.println(method.getModifiers()); System.out.println(method.getReturnType()); System.out.println(method.getReturnType().getName()); System.out.println(method.getReturnType().getSimpleName());
System.out.println(method.getName());
② 查询该方法的所有参数的类型:
Class[] cs = method.getParameterTypes();
for(Class c:cs){
System.out.println(c.getName());
}
一个类中的所有公有性方法:
Method[] methods = clazz2.getMethods();
for(Method c:methods){
System.out.println(c.getName()); System.out.println(c.getModifiers());
}
若为:Method[] methods = clazz2.getDeclaredMethods();
则是一个类里的全部方法;
③ 类中构造方法的地址:
Constructor constructor = clazz3.getConstructor();
Constructor constructor = clazz3.getDeclaredConstructor();
Constructor[] constructors = clazz3.getConstructors();
Constructor[] constructors = clazz3.getDeclaredConstructors();
④ 执行
创建对象:Object obj = clazz1.newInstance();
获取方法:Method method = clazz2.getDeclaredMethod(“asd1”,String.class,int.class);
运行方法:Object o = method.invoke(obj,“sdf”,456);
System.out.println(o);
通用增删改方法:
package com.hrbu.util;
import java.lang.reflect.*;
import java.sql.*;
import java.util.*;
import com.mysql.jdbc.PreparedStatement;
import com.mysql.jdbc.Statement;
public class JDBCTemplete<E> {
public int updateInsertAndDelete(String sql, Object...objs){
int i = 0;
Connection conn = null;
PreparedStatement pstate = null;
//创建驱动
try {
Class.forName(ConfigManager.DRIVER);
//创建连接
conn = DriverManager.getConnection(ConfigManager.URL, ConfigManager.USERNAME,ConfigManager.PASSWORD);
//创建状态参数
//预处理
pstate = (PreparedStatement) conn.prepareStatement(sql);
for (int m=0;m<objs.length;m++){
pstate.setObject(m+1,objs[m]);
}
//执行sql,并获取返回值
i = pstate.executeUpdate();
} catch (Exception e) {
e.printStackTrace();
}finally{
//输出
System.out.print(i);
//关闭
try {
pstate.close();
} catch (SQLException e) {
e.printStackTrace();
}
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
return i;
}
public List<E> selectList(String sql,Class clazz){
Connection conn = null;
Statement state = null;
List<E> list = new ArrayList();
//创建驱动
try {
Class.forName(ConfigManager.DRIVER);
//创建连接
conn = DriverManager.getConnection(ConfigManager.URL,ConfigManager.USERNAME,ConfigManager.PASSWORD);
//创建状态参数
state = (Statement) conn.createStatement();
//执行sql,并获取返回值
ResultSet rs = state.executeQuery(sql);
while(rs.next()){
E e = (E)clazz.newInstance();
Field[] fs = clazz.getDeclaredFields();
for (Field f : fs) {
String method_name = "set"+Character.toUpperCase(f.getName().charAt(0))+f.getName().substring(1);
Method m = clazz.getMethod(method_name,f.getType());
if(f.getType().getSimpleName().equals("int")){
m.invoke(e,rs.getInt(f.getName()));
}else if(f.getType().getSimpleName().equals("Integer")){
m.invoke(e,rs.getInt(f.getName()));
}else if(f.getType().getSimpleName().equals("String")){
m.invoke(e,rs.getString(f.getName()));
}else if(f.getType().getSimpleName().equals("Double")){
m.invoke(e,rs.getDouble(f.getName()));
} else if(f.getType().getSimpleName().equals("double")){
m.invoke(e,rs.getDouble(f.getName()));
}
}
list.add(e);
}
} catch (Exception e) {
e.printStackTrace();
}finally {
//关闭
try {
state.close();
} catch (SQLException e) {
e.printStackTrace();
}
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
return list;
}
}