日期:2014-05-17  浏览次数:20713 次

怎样写一个java开源框架?
怎样写一个框架。我看到开源项目的框架都是一个或者几个jar。
那么该怎样生成jar呢?
以及开发一个框架需要注意什么地方?
要用到什么技术?
大家来讨论一下

------解决方案--------------------
如果看到有几个 jar 的话,除了是第三方的 jar 之外,就是分模块进行打包的,一般的话,还会有一个 All in One 的 jar 包。
------解决方案--------------------
探讨
怎样写一个框架。我看到开源项目的框架都是一个或者几个jar。
那么该怎样生成jar呢?
以及开发一个框架需要注意什么地方?
要用到什么技术?
大家来讨论一下

------解决方案--------------------
初学者一定要重视基础,这样才能立于不败之地
下面简单模拟hibernate,意思一下


import java.lang.reflect.Method;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.util.HashMap;
import java.util.Map;

import com.cn.coyote.model.Student;

//模拟Hibernate
public class Session {
/**
* @author wlf
* cfs:Colums and Fields
* methodNames:method name,for example getId,getAge.
*/
String tableName = "_student";
Map<String,String> cfs = new HashMap<String,String>();
String[] methodNames;
public Session(){
cfs.put("_id","id");
cfs.put("_name","name");
cfs.put("_age","age");
methodNames = new String[cfs.size()];
}
//the method used for save Student object to database.
public void save(Student s) throws Exception {

String sql = createSql();
String driver = "com.mysql.jdbc.Driver";
String url = "jdbc:mysql://localhost/hibernate";
String uname = "root";
String pwd = "admin";
Class.forName(driver);
Connection conn = DriverManager.getConnection(url,uname,pwd);
PreparedStatement ps = conn.prepareStatement(sql);
for(int i=0;i<methodNames.length;i++) {
Method m = s.getClass().getMethod(methodNames[i]);
Class<?> r = m.getReturnType();

if(r.getName().equals("java.lang.String")) {
String returnValue = (String)m.invoke(s);
ps.setString(i+1, returnValue);
}
if(r.getName().equals("int")) {
Integer returnValue = (Integer)m.invoke(s);
ps.setInt(i+1, returnValue);
}
System.out.println(m.getName()+m.getReturnType());
}
ps.executeUpdate();
ps.close();
conn.close();

}
//create sql statement
private String createSql() {
String str1 = "";//Map的键值
String str2 = "";//sql中的问号
int index = 0;
for(String s:cfs.keySet()) {
String value = cfs.get(s);
value = Character.toUpperCase(value.charAt(0)) + value.substring(1);
methodNames[index] = "get" + value;
str1 += s+",";
index ++;
}
str1 = str1.substring(0, str1.length()-1);
for(int i=0;i<cfs.size();i++) {
str2 +="?,";
}
System.out.println(str2);
str2 = str2.substring(0,str2.length()-1);

String sql= "insert into " + tableName + "(" + str1 + ") values (" + str2 + ")";
System.out.println(sql);
return sql;
}

}
测试类:
import com.cn.coyote.model.Student;
//模拟Hibernate
public class StudentTest {
public static void main(String[] args) throws Exception{
Student s = new Student();
s.setId(2);
s.setName("s1");
s.setAge(1);
Session session = new Session();
session.save(s);
}
}

model:
package com.cn.coyote.model;

public class Student {
private int id;
private String name;
private int age;
public int getId() {
return id;
}