
2005年7月21日
最近在弄swing,需要由JComponent生成BufferedImage,在CSDN上發(fā)現(xiàn)一個(gè)好例子。下面是范例:
Rectangle?rect?=?comp.getBounds();
?BufferedImage?bufImage?=?new?BufferedImage(rect.width,
???????????rect.height,
???????????BufferedImage.TYPE_INT_RGB);
?Graphics?g?=?bufImage.getGraphics();
?g.translate(-rect.x,?-rect.y);
?comp.paint(g);這樣,JComponent中的圖像就保存到BufferedImage中了。
原文的鏈接:
http://dev.csdn.net/article/13/13531.shtm
??????? 好久沒(méi)有寫(xiě)blog了,距離上次寫(xiě)幾乎已經(jīng)是半年前的事情了。

?這半年發(fā)生了不少事情。首先換了家公司,進(jìn)了家金融企業(yè),每天要西裝革履的,一開(kāi)始還真是不習(xí)慣。

?這里開(kāi)發(fā)是用的spring框架,以后要多研究研究spring的東西了。
??????? 第二件事就是和戀愛(ài)了三年的女友結(jié)婚了,從此兩人長(zhǎng)相廝守,不知道時(shí)間久了會(huì)不會(huì)審美疲勞。呵呵。

??????? 第三件事就是在深圳買(mǎi)了自己的小房子,雖然是小小的兩房,不過(guò)我們已經(jīng)很知足了。

?而且剛好是趕在房?jī)r(jià)大漲前買(mǎi)的,還算走了點(diǎn)運(yùn)氣。換到現(xiàn)在,都不知道去哪里買(mǎi)好了。
??????? 在這里要向一些留言和發(fā)郵件給我的網(wǎng)友道歉,前段時(shí)間實(shí)在是太忙,沒(méi)有空回復(fù)你們的信息和郵件。請(qǐng)?jiān)彛?img height="20" src="/Emoticons/QQ/15.gif" width="20" border="0" />
最近真是多事情忙,而且可能要忙到9月底。好久沒(méi)有上來(lái)更新我的博客了,暫且發(fā)發(fā)牢騷。
這一節(jié)是非常實(shí)用的一節(jié),我在閱讀此書(shū)的時(shí)候,一直在迷惑,究竟應(yīng)該怎樣管理Session呢?因?yàn)镾ession的管理是如此重要,類(lèi)似于以前寫(xiě)程序?qū)DBC Connection的管理。看完此節(jié)后,終于找到了方法。
在各種Session管理方案中,ThreadLocal模式得到了大量使用。ThreadLocal是Java中一種較為特殊的線程綁定機(jī)制。通過(guò)ThreadLocal存取的數(shù)據(jù),總是與當(dāng)前線程相關(guān),也就是說(shuō),JVM為每個(gè)運(yùn)行的線程,綁定了私有的本定實(shí)例存取空間,從而為多線程環(huán)境經(jīng)常出現(xiàn)的并發(fā)訪問(wèn)問(wèn)題提供了一種隔離機(jī)制。
下面是Hibernate官方提供的一個(gè)ThreadLocal工具:
import net.sf.hibernate.*;
import net.sf.hibernate.cfg.*;
import org.apache.log4j.Logger;


/**//**
* <p>Title: </p>
*
* <p>Description: Session的管理類(lèi)</p>
*
* <p>Copyright: Copyright (c) 2005</p>
*
* <p>Company: </p>
*
* @author George Hill
* @version 1.0
*/


public class HibernateUtil
{

private static final Logger log = Logger.getLogger(HibernateUtil.class);

private static final SessionFactory sessionFactory;


/**//**
* 初始化Hibernate配置
*/

static
{

try
{
// Create the SessionFactory
sessionFactory = new Configuration().configure().buildSessionFactory();

} catch (Throwable ex)
{
log.error("Initial SessionFactory creation failed.", ex);
throw new ExceptionInInitializerError(ex);
}
}

public static final ThreadLocal session = new ThreadLocal();


/**//**
* 根據(jù)當(dāng)前線程獲取相應(yīng)的Session
* @return Session
* @throws HibernateException
*/

public static Session currentSession() throws HibernateException
{
Session s = (Session) session.get();
// Open a new Session, if this Thread has none yet

if (s == null)
{
s = sessionFactory.openSession();
session.set(s);
}
return s;
}


/**//**
* 返回Session給相應(yīng)的線程
* @throws HibernateException
*/

public static void closeSession() throws HibernateException
{
Session s = (Session) session.get();
session.set(null);
if (s != null)
s.close();
}

}

針對(duì)WEB程序,還可以利用Servlet2.3的Filter機(jī)制,輕松實(shí)現(xiàn)線程生命周期內(nèi)的Session管理。下面是一個(gè)通過(guò)Filter進(jìn)行Session管理的典型案例:

public class PersistenceFilter implements Filter
{
protected static ThreadLocal hibernateHolder = new ThreadLocal();


public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException
{
hibernateHolder.set(getSession());

try
{


chain.doFilter(request, response);



} finally
{
Session session = (Session) hibernateHolder.get();

if (session != null)
{
hibernateHolder.set(null);

try
{
session.close();

} catch (HibernateException ex)
{
throw new ServletException(ex);
}
}
}
}


}
數(shù)據(jù)分頁(yè)顯示,是很多B/S系統(tǒng)會(huì)遇到的問(wèn)題。現(xiàn)在大多數(shù)主流數(shù)據(jù)庫(kù)都提供了數(shù)據(jù)部分讀取機(jī)制,而對(duì)于某些沒(méi)有提供相應(yīng)機(jī)制的數(shù)據(jù)而言,Hibernate也通過(guò)其它途徑實(shí)現(xiàn)了分頁(yè),如通過(guò)Scrollable ResultSet,如果JDBC不支持Scrollable ResultSet,Hibernate也會(huì)自動(dòng)通過(guò)ResultSet的next方法進(jìn)行記錄定位。Hibernate的Criteria、Query等接口提供了一致的方法設(shè)定分頁(yè)范圍。下面是書(shū)中的例子:
Criteria criteria = session.createCriteria(TUser.class);
Criteria.add(Expression.eq("age", "20"));
//從檢索結(jié)果中獲取第100條記錄開(kāi)始的20條記錄
criteria.setFirstResult(100);
criteria.setFetchSize(20); 不過(guò),我在測(cè)試的時(shí)候總是不能夠正常工作,把setFetchSize方法換成setMaxResults方法才行。換成最新的mysql-connector-java-3.1.10-bin-g.jar驅(qū)動(dòng)也是一樣。
Hibernate通過(guò)Lifecycle、Validatable接口制定了實(shí)體對(duì)象CRUD過(guò)程中的回調(diào)方式。
Lifecycle接口中的onSave、onUpdate、onDelete方法,如果返回true則意味著需要中止執(zhí)行相應(yīng)的操作過(guò)程。如果代碼運(yùn)行期間拋出了CallbackException,對(duì)應(yīng)的操作也會(huì)被中止。注意,不要試圖在這些方法中調(diào)用Session進(jìn)行持久化操作,這些方法中Session無(wú)法正常使用。
Validatable.validate方法將在實(shí)體被持久化之前得到調(diào)用以對(duì)數(shù)據(jù)進(jìn)行驗(yàn)證。此方法在實(shí)體對(duì)象的生命周期內(nèi)可能被數(shù)次調(diào)用,因此,此方法僅用于數(shù)據(jù)本身的邏輯校驗(yàn),而不要試圖在此實(shí)現(xiàn)業(yè)務(wù)邏輯的驗(yàn)證。
Hibernate還引入了Interceptor,為持久化事件的捕獲和處理提供了一個(gè)非侵略性的實(shí)現(xiàn)。Interceptor接口定義了Hibernate中的通用攔截機(jī)制。Session創(chuàng)建時(shí)即可指定加載相應(yīng)的Interceptor,之后,此Session的持久化操作動(dòng)作都將首先經(jīng)由此攔截器捕獲處理。簡(jiǎn)單的加載范例如下:
SessionFactory factory = config.buildSessionFactory();
Interceptor it = new MyInterceptor();
session = sessionFactory.openSession(it); 需要注意的是,與Lifecycle相同,Interceptor的方法中不可通過(guò)Session實(shí)例進(jìn)行持久化操作。