日期:2014-05-20  浏览次数:20613 次

函数的参数问题 ... 求科普!
首先,我来段反射代码:

/******
 * @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()];
}
public void save(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();
}
private String createSQL() {
 //SQL:insert into _Students(_id,_age,_name) values(?,?,?)
 //str1代表的是【_id,_age,_name】部分
 String str1 = "" ;
 int index = 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 += "?"+",";