<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-57  評論-202  文章-17  trackbacks-0
      2005年7月20日
    最近在弄swing,需要由JComponent生成BufferedImage,在CSDN上發(fā)現(xiàn)一個好例子。下面是范例:

    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
    posted @ 2006-04-14 23:41 小米 閱讀(1383) | 評論 (1)編輯 收藏
    ??????? 好久沒有寫blog了,距離上次寫幾乎已經(jīng)是半年前的事情了。?這半年發(fā)生了不少事情。首先換了家公司,進了家金融企業(yè),每天要西裝革履的,一開始還真是不習(xí)慣。?這里開發(fā)是用的spring框架,以后要多研究研究spring的東西了。
    ??????? 第二件事就是和戀愛了三年的女友結(jié)婚了,從此兩人長相廝守,不知道時間久了會不會審美疲勞。呵呵。
    ??????? 第三件事就是在深圳買了自己的小房子,雖然是小小的兩房,不過我們已經(jīng)很知足了。?而且剛好是趕在房價大漲前買的,還算走了點運氣。換到現(xiàn)在,都不知道去哪里買好了。
    ??????? 在這里要向一些留言和發(fā)郵件給我的網(wǎng)友道歉,前段時間實在是太忙,沒有空回復(fù)你們的信息和郵件。請原諒!
    posted @ 2006-03-29 19:43 小米 閱讀(788) | 評論 (0)編輯 收藏
          最近真是多事情忙,而且可能要忙到9月底。好久沒有上來更新我的博客了,暫且發(fā)發(fā)牢騷。
    posted @ 2005-08-10 17:32 小米 閱讀(1184) | 評論 (1)編輯 收藏
          這一節(jié)是非常實用的一節(jié),我在閱讀此書的時候,一直在迷惑,究竟應(yīng)該怎樣管理Session呢?因為Session的管理是如此重要,類似于以前寫程序?qū)DBC Connection的管理。看完此節(jié)后,終于找到了方法。
          在各種Session管理方案中,ThreadLocal模式得到了大量使用。ThreadLocal是Java中一種較為特殊的線程綁定機制。通過ThreadLocal存取的數(shù)據(jù),總是與當前線程相關(guān),也就是說,JVM為每個運行的線程,綁定了私有的本定實例存取空間,從而為多線程環(huán)境經(jīng)常出現(xiàn)的并發(fā)訪問問題提供了一種隔離機制。
          下面是Hibernate官方提供的一個ThreadLocal工具:


    import net.sf.hibernate.
    *;
    import net.sf.hibernate.cfg.
    *;
    import org.apache.log4j.Logger;

    /**
     * <p>Title: </p>
     *
     * <p>Description: Session的管理類</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ù)當前線程獲取相應(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();
      }


    }


          針對WEB程序,還可以利用Servlet2.3的Filter機制,輕松實現(xiàn)線程生命周期內(nèi)的Session管理。下面是一個通過Filter進行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);
            }

          }

        }

      }

      
    }
    posted @ 2005-07-29 19:43 小米 閱讀(3938) | 評論 (1)編輯 收藏
          數(shù)據(jù)分頁顯示,是很多B/S系統(tǒng)會遇到的問題。現(xiàn)在大多數(shù)主流數(shù)據(jù)庫都提供了數(shù)據(jù)部分讀取機制,而對于某些沒有提供相應(yīng)機制的數(shù)據(jù)而言,Hibernate也通過其它途徑實現(xiàn)了分頁,如通過Scrollable ResultSet,如果JDBC不支持Scrollable ResultSet,Hibernate也會自動通過ResultSet的next方法進行記錄定位。Hibernate的Criteria、Query等接口提供了一致的方法設(shè)定分頁范圍。下面是書中的例子:

    Criteria criteria = session.createCriteria(TUser.class);
    Criteria.add(Expression.eq(
    "age""20"));
    //從檢索結(jié)果中獲取第100條記錄開始的20條記錄
    criteria.setFirstResult(100);
    criteria.setFetchSize(
    20);

          不過,我在測試的時候總是不能夠正常工作,把setFetchSize方法換成setMaxResults方法才行。換成最新的mysql-connector-java-3.1.10-bin-g.jar驅(qū)動也是一樣。
    posted @ 2005-07-26 18:12 小米 閱讀(5554) | 評論 (4)編輯 收藏

          Hibernate通過Lifecycle、Validatable接口制定了實體對象CRUD過程中的回調(diào)方式。
          Lifecycle接口中的onSave、onUpdate、onDelete方法,如果返回true則意味著需要中止執(zhí)行相應(yīng)的操作過程。如果代碼運行期間拋出了CallbackException,對應(yīng)的操作也會被中止。注意,不要試圖在這些方法中調(diào)用Session進行持久化操作,這些方法中Session無法正常使用。
          Validatable.validate方法將在實體被持久化之前得到調(diào)用以對數(shù)據(jù)進行驗證。此方法在實體對象的生命周期內(nèi)可能被數(shù)次調(diào)用,因此,此方法僅用于數(shù)據(jù)本身的邏輯校驗,而不要試圖在此實現(xiàn)業(yè)務(wù)邏輯的驗證。



          Hibernate還引入了Interceptor,為持久化事件的捕獲和處理提供了一個非侵略性的實現(xiàn)。Interceptor接口定義了Hibernate中的通用攔截機制。Session創(chuàng)建時即可指定加載相應(yīng)的Interceptor,之后,此Session的持久化操作動作都將首先經(jīng)由此攔截器捕獲處理。簡單的加載范例如下:

    SessionFactory factory = config.buildSessionFactory();
    Interceptor it 
    = new MyInterceptor();
    session 
    = sessionFactory.openSession(it);

          需要注意的是,與Lifecycle相同,Interceptor的方法中不可通過Session實例進行持久化操作。
    posted @ 2005-07-21 18:35 小米 閱讀(3364) | 評論 (1)編輯 收藏
          有興趣的可以去參加看看,網(wǎng)址:http://www.javachina.cn/Index.jsp
    posted @ 2005-07-20 14:55 小米 閱讀(1023) | 評論 (2)編輯 收藏

          最近真是忙,事情都擠到一塊去了。 終于有時間又看了幾頁書。
          言歸正傳,Hibernate中的Collection類型分為有序集和無序集兩類。這里所謂的有序和無序,是針對Hibernate數(shù)據(jù)持久過程中,是否保持數(shù)據(jù)集合中的記錄排列順序加以區(qū)分的。無序集有Set,Bag,Map幾種,有序集有List一種。有序集的數(shù)據(jù)在持久化過程中,會將集合中元素排列的先后順序同時固化到數(shù)據(jù)庫中,讀取時也會返回一個具備同樣排列順序的數(shù)據(jù)集合。
          Hibernate中的Collection類型是用的自己的實現(xiàn),所以在程序中,不能夠把接口強制轉(zhuǎn)化成相應(yīng)的JDK Collection的實現(xiàn)。



          結(jié)果集的排序有兩種方式:
          1. Sort
             Collection中的數(shù)據(jù)排序。
          2. order-by
             對數(shù)據(jù)庫執(zhí)行Select SQL時,由order by子句實現(xiàn)的數(shù)據(jù)排序方式。

          需要注意的是,order-by特性在實現(xiàn)中借助了JDK 1.4中的新增集合類LinkedHashSet以及LinkedHashMap。因此,order-by特性只支持在1.4版本以上的JDK中運行。

    posted @ 2005-07-20 10:56 小米 閱讀(3943) | 評論 (0)編輯 收藏
    主站蜘蛛池模板: 亚洲精华液一二三产区| 人妻无码中文字幕免费视频蜜桃| 女人被男人躁的女爽免费视频| 久久精品熟女亚洲av麻豆| 中文字幕乱码免费看电影| 亚洲欧洲免费视频| 在线成人a毛片免费播放| 精品国产免费一区二区三区| 亚洲系列中文字幕| 亚洲а∨天堂久久精品| 8x网站免费入口在线观看| 香港特级三A毛片免费观看| 久久久久久亚洲精品| 午夜免费福利在线观看| a在线观看免费视频| 亚洲第一第二第三第四第五第六| 亚洲午夜未满十八勿入网站2| 美女巨胸喷奶水视频www免费| 亚洲色图综合网站| 亚洲一级特黄大片无码毛片| 国产va精品免费观看| 你是我的城池营垒免费观看完整版 | 久久亚洲精品人成综合网| 性xxxx视频免费播放直播| mm1313亚洲国产精品无码试看| 亚洲AV无码一区二区二三区入口| 好吊妞788免费视频播放| 最近2022中文字幕免费视频| 四虎成人精品国产永久免费无码| 亚洲ts人妖网站| 亚洲人成在线电影| 亚洲最大AV网站在线观看| 免费无码又爽又刺激高潮的视频 | 羞羞网站在线免费观看| 亚洲伦理一二三四| 亚洲精品国产精品乱码不卡√| 久久久久免费看成人影片| 久香草视频在线观看免费| 亚洲国产视频久久| 亚洲AV无码成H人在线观看| 日韩毛片免费无码无毒视频观看|