函数的参数问题 ... 求科普!
首先,我来段反射代码:
/******
* @introduce:
* 1、这个类是Hibernate中模拟Session的部分
* 2、这个类,由于有些部分与问题无关,
* 为了不影响阅读,我这里把与问题相关的核心部分发出来!
*/
public class MySession {
String tableName = "_Students";//表名
Map<String , String> cfg = new HashMap<String , String>();//<表字段名,实体属性名>
String[] mName;//将实体中getXxx()用数组表示
private Student s;
//初始化
public MySession(){//这是MySession的构造函数
cfg.put("_id", "id");
cfg.put("_name", "name");
cfg.put("_age", "age");
mName = new String[cfg.size()];
}
publicvoidsave(Student s)throws Exception
{
String sql = createSQL();
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl","system","weidu23");
PreparedStatement pst = conn.prepareStatement(sql);
for(int i =0 ; i <mName.length;i++)
{
String m = mName[i];
Method methodName = s.getClass().getMethod(m);
Class<?> returnType = methodName.getReturnType();
if( returnType.getName().equals("int"))
{
pst.setInt(i+1, (Integer)methodName.invoke(s));
}
else if(returnType.getName().equals("java.lang.String"))
{
pst.setString(i+1, (String)methodName.invoke(s));
}
else if(returnType.getName().equals("java.sql.Date"))
{
pst.setDate(i+1,(java.sql.Date)methodName.invoke(s));
}
else
;
}
pst.executeQuery();
pst.close();
pst.close();
}
privateStringcreateSQL() {
//SQL:insert into _Students(_id,_age,_name) values(?,?,?)
//str1代表的是【_id,_age,_name】部分
String str1="";
intindex=0;
for(String s:cfg.keySet()){
str1 += s+"," ;
String v = cfg.get(s);
String m = "get" + Character.toUpperCase(v.charAt(0)) + v.substring(1);
mName[index] = m ;
index++;
}
str1 = str1.substring(0, str1.length()-1);
System.out.println(str1);
//str2代表的是【?,?,?】部分
String str2 = "";
//拼接str2
for(int i=0;i<cfg.size();i++){
str2 += "?"+",";
}
str2 = str2.substring(0,str2.length()-1);
System.out.println(str2);
//组装SQL语句
String sql = "insert into " + tableName + "(" + str1 + ")" + " values(" + str2 + ")";
System.out.println(sql);
return sql;
}
}
public Method getMethod(String name,Class<?>... parameterTypes)
throws NoSuchMethodException,SecurityException
class Test
{
public void fun();
public void fun(int a);
public void fun(int a,String b)
}
Test.getClass().getMethod("fun"); //first
Test.getClass().getMethod("fun",Integer.class); //Second
Test.getClass().getMethod("fun",Integer.class,String.class); //Third