隨筆-57  評論-202  文章-17  trackbacks-0
           

                現(xiàn)在搜狐新聞上報(bào)道已經(jīng)有700多人傷亡,這是自從911事件以后最大的一次恐怖襲擊了。現(xiàn)在這個(gè)世界,是越來越不太平了,貧富差距的加大使得恐怖活動有生存的土壤。
                不知道世界的經(jīng)濟(jì)會不會隨著這次恐怖襲擊而開始走向蕭條。現(xiàn)在的地球越來越像一個(gè)村,發(fā)生在任何一個(gè)角落的事情,都有可能會影響到每一個(gè)人。

          posted @ 2005-07-08 10:50 小米 閱讀(662) | 評論 (0)編輯 收藏
                昨晚偶然看見國際臺播放星戰(zhàn)的作者喬治盧卡斯榮獲AFI終身成就獎的頒獎典禮,耐心的看完了整個(gè)頒獎典禮。喬治在發(fā)表致詞的時(shí)候,說自己很高興能夠從事自己喜歡的電影工作,如果不拍攝電影,都不知道自己還能夠做什么。拍電影已經(jīng)成了喬治生命的一部分。
                看到熒屏上全世界的老人,中年人,年輕人,孩子說著:“Thank you! George.”可以看到喬治的眼睛朦朧。我心中真是感慨,每個(gè)人都有自己的夢想,能夠從事自己喜歡的事情,確實(shí)是很開心的一件事。而自己所做的工作,能夠給自己帶來快樂,能夠給人們帶來快樂,這樣的工作才值得用一生的時(shí)間去從事。
                每一個(gè)登山者都有著自己心目中最想登上的山頂,能夠登上這個(gè)山頂,前面付出的艱辛都是值得的。人生不也如此么?找到自己喜歡從事的事情,用自己畢生的精力去做這件事。
          posted @ 2005-07-07 12:00 小米 閱讀(664) | 評論 (0)編輯 收藏
          獻(xiàn)出一份愛心 共同援助重病程序員王俊
          (2005.06.27)   來自:BJUG  
           

          向IT界倡議:援助程序員王俊行動

          王俊,今年27歲,北京北方銀證公司項(xiàng)目經(jīng)理,是北京Java用戶組(BJUG,
          員(http://forum.javaeye.com/profile.php?mode=viewprofile&u=33)。一個(gè)年輕
          人,有感興趣的工作,不錯(cuò)的前途,還有一群可以隨時(shí)交流技術(shù)的朋友,生活看起來平
          淡卻充實(shí)。

          業(yè)余時(shí)間,王俊經(jīng)常還利用blog(http://befresh.blogbus.com)寫下自己生活和工作
          中的酸甜苦辣,此外他還有一個(gè)并不富裕但卻很溫馨的家。

          然而從今年二月份起,王俊的blog就再也沒有更新過了,他也沒有在BJUG的聚會和
          javaeye出現(xiàn)了,所有人都以為他出差去了。直到最近,驚聞他要換骨髓,才知道今年
          年初,王俊被查出患有“骨髓增生異常綜合癥”。

          骨髓增生異常綜合征目前認(rèn)為是造血干細(xì)胞增殖分化異常所致的造血功能障礙。主要表
          現(xiàn)為外周血全血細(xì)胞減少,骨髓細(xì)胞增生,成熟和幼稚細(xì)胞有形態(tài)異常即病態(tài)造血。部
          分患者在經(jīng)歷一定時(shí)期的MDS后轉(zhuǎn)化成為急性白血病;部分因感染、出血或其他原因死
          亡,病程中始終不轉(zhuǎn)化為急性白血病。

          這種病目前最有效的治療手段是換骨髓。萬幸的是,王俊的妹妹和他的骨髓配型一致,
          免疫系統(tǒng)的疾病發(fā)現(xiàn)治療的越早,就越可能成功,他目前的身體狀況還好,只要能更換
          骨髓,完全可以康復(fù)!但讓他們一家望而卻步的是,僅手術(shù)押金就需要20萬,全部療程
          視治療效果可能需要30-100萬。

          王俊的家在浙江杭州千島湖,父母都是農(nóng)民,已然老邁且沒有固定的經(jīng)濟(jì)收入,姐姐在
          當(dāng)?shù)爻黾蓿杖腩H低,妹妹目前在北京讀成人教育并在公司打工。王俊是家庭經(jīng)濟(jì)主要
          來源,他的病不僅掐斷了家里唯一的經(jīng)濟(jì)來源,還要花上對他們而言是天文數(shù)字的錢來
          治病。

          "文章千古事,得失寸心知",這是王俊blog上的座右銘。細(xì)細(xì)翻看這個(gè)典型程序員的
          blog,就和他的人一樣樸實(shí)無華,在那里滿眼看到的都是對技術(shù)的孜孜追求。誰能想到
          一個(gè)如此活躍的頭腦現(xiàn)在卻被病魔折磨著。

          生命是美好的,這世界每天都有若干悲劇發(fā)生,這次,大家每個(gè)人出一份力,這世界就
          會少一個(gè)悲劇,多一份美好,多一份歡笑。也許,你只是少吃一頓大餐,少買一瓶化妝
          品,少看一場演唱會,少買一件名牌服裝,少玩一個(gè)月的網(wǎng)絡(luò)游戲,少上一個(gè)月的網(wǎng),
          但是你卻可以為一個(gè)家庭托起一份生的希望。

          *****

          聯(lián)系方式 
          郵件 help@bjug.org
          MSN  icecloud@sina.com 冰云(BJUG) 

          援助辦法:

          1 捐款
          帳號:
          工商銀行
          戶名 王俊
          帳號 0200 2008 0102 3428 807
          開戶行 工商銀行北京市西內(nèi)所

          招商銀行
          戶名 王俊
          帳號 9555 5001 0200 2820
          開戶行 招商銀行 北京分行

          中國銀行
          戶名 王俊
          帳號 4021400-0188-001204-0
          開戶行 北京西直門支行

          國外匯款方式
          ADD: BANK OF CHINA BEIJING BRANCH
          NO.8 YA BAO LU
          BEIJING, CHINA
          SWIFT-CODE: BKCHCNBJ110
          A/CNo: 4021400-0188-001204-0
          NAME: WANG JUN

          捐款方式:
          A 網(wǎng)上銀行
          工行請采用行內(nèi)匯款->有收款帳號匯款
          招行請采用個(gè)人銀行專業(yè)版的同城轉(zhuǎn)帳/異地匯款,并選中:采用系統(tǒng)內(nèi)快速匯款

          B 銀行匯款
          請抄錄上述帳號并到銀行填寫匯款單

          請?jiān)诰杩詈螅l(fā)郵件至help@bjug.org,通知我們,以便統(tǒng)計(jì)核對捐款帳目。郵件中請說明以下信息:
           (1) 姓名,
          (2) id/網(wǎng)站,
          (3) 發(fā)出銀行/發(fā)出帳號,
          (4) 金額,
          (5) 時(shí)間

          2 幫助宣傳:

          • 請到http://befresh.bjug.org 留下你對他的祝福
          • 請?jiān)贛SN上修改您的名字,我們都寫上 [祝福后山]
          • 請修改您MSN的頭像為我們提供的圖標(biāo)
          • 增加行動網(wǎng)站的地址 http://befresh.bjug.org 到MSN名字后面的個(gè)人信息
          • 請看到此文的Blogger,在您的blog上link此文,并Trackback到后山的blog
          • 請看到此信息的人,幫助一起宣傳,我們需要您的幫助
          • 在您的BLOG或網(wǎng)站,加上用我們提供的LOGO,并連接到網(wǎng)站http://befresh.bjug.org
          • 泡論壇的,請修改你的論壇LOGO和簽名檔為提供的圖標(biāo)

           

          *****

          聯(lián)合發(fā)起:
          BJUG http://www.bjug.org <http://www.bjug.org/
          CSDN http://www.csdn.net <http://www.csdn.net/
          JavaEye http://www.javaeye.com <http://www.javaeye.com/
          JActionGroup http://www.jactiongroup.net/
          Huihoo http://www.huihoo.org <http://www.huihoo.org/
          RedSaga http://www.redsaga.com <http://www.redsaga.com/>  
          Matrix http://www.matrix.org.cn <http://www.matrix.org.cn/>
          Blogbus http://www.blogbus.com <http://www.blogbus.com/

          posted @ 2005-07-04 18:48 小米 閱讀(1711) | 評論 (22)編輯 收藏
               摘要:       要將BufferedImage實(shí)例保存為BMP文件,就需要知道BMP文件的格式,可以參考我轉(zhuǎn)載的文章:《BMP文件格式》。      下面是我的將BufferedImage實(shí)例保存為24位色BMP文件的實(shí)現(xiàn)。     ...  閱讀全文
          posted @ 2005-07-04 17:33 小米 閱讀(3440) | 評論 (6)編輯 收藏
                在公元2005年6月27日,我做出了一個(gè)重大的決定,買房!花了自己至今為止都沒有見過的那么多的錢買了一個(gè)小小的2房2廳, 從此變成了“負(fù)翁”。
                不過,從此以后再也不用去租房,再也不用幫別人供房,再也不用一年搬一次家。深圳租房實(shí)在太貴,蓮花北的一個(gè)小小的二房都要1800,有點(diǎn)裝修就叫豪華裝修,就是一個(gè)空蕩蕩的房子也開口要1500,太夸張了。住農(nóng)民房又極度不安全,不想拿自己的生命開玩笑。
                從此就變成月供一族了,,不過,有了壓力才有動力。為了自己的將來,自己的理想,努力奮斗!
                9月26日是入伙的日子,好期待那天的到來啊。
          posted @ 2005-06-29 09:47 小米 閱讀(923) | 評論 (9)編輯 收藏
                一般而言,ORM的數(shù)據(jù)緩存應(yīng)包含如下幾個(gè)層次:
                1. 事務(wù)級緩存(Transcation Layer Cache)
                2. 應(yīng)用級/進(jìn)程級緩存(Application/Process Layer Cache)
                3. 分布式緩存(Cluster Layer Cache)

                Hibernate數(shù)據(jù)緩存(Cache)分為兩個(gè)層次,以Hibernate語義加以區(qū)分,可分為:
                1. 內(nèi)部緩存(Session Level,也稱為一級緩存)
                2. 二級緩存(SessionFactory Level,也稱為二級緩存)

                Hibernate中,緩存將在以下情況中發(fā)揮作用:
                1. 通過id[主鍵]加載數(shù)據(jù)時(shí)
                2. 延遲加載

                內(nèi)部緩存正常情況下由Hibernate自動維護(hù),如果需要手動干預(yù),可以通過以下方法完成:
                1. Session.evict
                   將某個(gè)特定對象從內(nèi)部緩存清除。
                2. Session.clear
                   清空內(nèi)部緩存。

                在Hibernate中,二級緩存涵蓋了應(yīng)用級緩存和分布式緩存領(lǐng)域。如果數(shù)據(jù)滿足以下條件,則可將其納入緩存管理。
                1. 數(shù)據(jù)不會被第三方應(yīng)用修改;
                2. 數(shù)據(jù)大小(Data Size)在可接收的范圍之內(nèi);
                3. 數(shù)據(jù)更新頻率較低;
                4. 同一數(shù)據(jù)可能會被系統(tǒng)頻繁引用;
                5. 非關(guān)鍵數(shù)據(jù)(關(guān)鍵數(shù)據(jù),如金融帳戶數(shù)據(jù))。
                Hibernate本身并未提供二級緩存的產(chǎn)品化實(shí)現(xiàn),而是為眾多的第三方緩存組件提供了接入接口,較常用的第三方組件有:
                1. JCS
                2. EHCache
                3. OSCache
                4. JBossCache
                5. SwarmCache
                Hibernate中啟用二級緩存,需要在hibernate.cfg.xml配置hibernate.cache.provider_class參數(shù),之后,需要在映射文件中指定各個(gè)映射實(shí)體(以及collection)的緩存同步策略。Hibernate提供了一下4種內(nèi)置的緩存同步策略:
                1. read-only
                   只讀。對于不會發(fā)生改變的數(shù)據(jù),可使用只讀型緩存。
                2. nonstrict-read-write
                   如果程序?qū)Σl(fā)訪問下的數(shù)據(jù)同步要求不是非常嚴(yán)格,且數(shù)據(jù)更新操作頻率較低,可以采用本選項(xiàng),獲得較好的性能。
                3. read-write
                   嚴(yán)格可讀寫緩存。基于時(shí)間戳判定機(jī)制,實(shí)現(xiàn)了“read committed”事務(wù)隔離等級。可用于對數(shù)據(jù)同步要求嚴(yán)格的情況,但不支持分布式緩存。這也是實(shí)際應(yīng)用中使用最多的同步策略。
                4. transactional
                   事務(wù)型緩存,必須運(yùn)行在JTA事務(wù)環(huán)境中。
          posted @ 2005-06-22 18:15 小米 閱讀(6116) | 評論 (5)編輯 收藏

                在Java語言中,對象之間的比較可以通過引用比較(==)和內(nèi)容比較(equals)兩種方式進(jìn)行,而在Hibernate的實(shí)體對象的比較是通過主鍵值來比較,如果要實(shí)現(xiàn)自己的識別邏輯,則需要重寫equals方法和hashCode方法。

                檢查數(shù)據(jù)對象改變檢查的一般策略有下面兩種:
                1. 數(shù)據(jù)對象監(jiān)控
                   數(shù)據(jù)對象監(jiān)控的實(shí)現(xiàn)方式,通過攔截器對數(shù)據(jù)對象的設(shè)值方法進(jìn)行攔截。一旦數(shù)據(jù)對象的設(shè)置方法被調(diào)用,則將其標(biāo)志為“待更新”狀態(tài),之后在數(shù)據(jù)庫操作時(shí)將其更新到對應(yīng)的庫表。
                2. 數(shù)據(jù)版本對比
                   在持久層框架中維持?jǐn)?shù)據(jù)對象的最近讀取版本,當(dāng)數(shù)據(jù)提交時(shí)將提交數(shù)據(jù)與此版本進(jìn)行比對,如果發(fā)生變化則將其同步到數(shù)據(jù)庫對應(yīng)的庫表。

                Hibernate采取的是第二種檢查策略。它采用一個(gè)內(nèi)部數(shù)據(jù)結(jié)構(gòu)"EntityEntry"保存對應(yīng)實(shí)體類的狀態(tài)信息。

                對于級聯(lián)對象的更新,Hibernate將根據(jù)unsaved-value進(jìn)行判定。首先Hibernate會取出目標(biāo)對象的id。之后,將此值與unsaved-value進(jìn)行比對,如果相等,則認(rèn)為目標(biāo)對象尚未保存,否則,認(rèn)為對象已經(jīng)保存,無需再進(jìn)行保存操作。

          posted @ 2005-06-22 16:32 小米 閱讀(5163) | 評論 (4)編輯 收藏
                最近正在研讀《深入淺出Hibernate》一書,前面寫的隨筆有些也是讀該書的筆記,只是未做歸類,從這篇開始,我將把相關(guān)的內(nèi)容都整理成一個(gè)系列的讀書筆記。
                今天這篇是有關(guān)實(shí)體對象的生命周期。我剛開始接觸Hibernate的時(shí)候,只是簡單的把它當(dāng)做一個(gè)API工具,直到后來看到有關(guān)VO和PO的內(nèi)容時(shí),才意識到Hibernate不僅僅是一個(gè)O/R Mapping的API工具,它還是一個(gè)容器。它可以幫你管理實(shí)體對象的生命周期。

                實(shí)體對象的生命周期有三種狀態(tài):
                1.Transient(自由狀態(tài))
                此時(shí)的實(shí)體對象和數(shù)據(jù)庫中的記錄無關(guān)聯(lián),只是一個(gè)普通的JavaBean。
                2.Persistent(持久狀態(tài))
                此時(shí)的實(shí)體對象和數(shù)據(jù)庫中的記錄有關(guān)聯(lián),其變更將由Hibernate固化到數(shù)據(jù)庫中。該實(shí)體對象處于由Hibernate框架所管理的狀態(tài)。
                3.Detached(游離狀態(tài))
                處于Persistent狀態(tài)的對象,其對應(yīng)的Session實(shí)例關(guān)閉之后,那么,此對象就處于"Detached"狀態(tài)。Detached狀態(tài)和Transient狀態(tài)的區(qū)別在于Detached狀態(tài)的對象可以再次與某個(gè)Session實(shí)例相關(guān)聯(lián)而成為Persistent對象。

                從實(shí)體對象是否被納入Hibernate實(shí)體管理容器的角度,Transient和Detached狀態(tài)的實(shí)體對象可以統(tǒng)稱為VO(Value Object),而被管理的實(shí)體對象稱為PO(Persistent Object)。兩者的區(qū)別:
                1.VO是相對獨(dú)立的實(shí)體對象,處于非管理狀態(tài)。
                2.PO是Hibernate納入其實(shí)體管理容器(Entity Map)的對象,它代表了與數(shù)據(jù)庫中某條記錄對應(yīng)的Hibernate實(shí)體,PO的變化在事務(wù)提交時(shí)將反映到實(shí)際數(shù)據(jù)庫中。
                3.如果一個(gè)PO與其對應(yīng)的Session實(shí)例分離,那么此時(shí),它又會變成一個(gè)VO。

                下圖是我畫的實(shí)體對象生命周期的狀態(tài)轉(zhuǎn)換圖:

          vopolife.JPG
          posted @ 2005-06-16 18:31 小米 閱讀(3085) | 評論 (9)編輯 收藏
                在使用HQL查詢中,有時(shí)并不需要獲取完整的一個(gè)實(shí)體對象,例如一個(gè)實(shí)體對象User有三個(gè)屬性:account, password和email,如果我們只需要獲取account和email屬性,那么有兩種方法可以選擇。
                1. 用普通的"select user.account, user.email from User as user",程序片斷如下:

              List list = session.createQuery("select user.account, user.email from User as user").list();
              Iterator it 
          = list.iterator();
              
          while (it.hasNext()) {
                Object[] values 
          = (Object[]) it.next();
                System.
          out.println(values[0+ " " + values[1]);
              }

                這時(shí)調(diào)用Query類的list方法返回的將是一個(gè)每個(gè)元素都是一個(gè)Object數(shù)組的List。如果只獲取一個(gè)屬性,那么返回的List中的每個(gè)元素都是String實(shí)例。

                2.在HQL中用new操作符生成實(shí)體對象,例如:"select new User(user.account, user.email) from User as user",程序片斷如下:

              List list = session.createQuery("select new User(user.account, user.email) from User as user").list();
              Iterator it 
          = list.iterator();
              
          while (it.hasNext()) {
                User user 
          = (User) it.next();
                System.
          out.println(user.getAccount() + " " + user.getEmail());
              }

                這時(shí)list方法返回的List中的每一個(gè)元素都是User實(shí)體對象。這里有三點(diǎn)需要注意的:
                a.在HQL語句中需要使用as操作符指定User的別名,并且需要在構(gòu)造函數(shù)的屬性前面加上別名;
                b.HQL語句中的構(gòu)造函數(shù)在User類中必須要有相應(yīng)的構(gòu)造函數(shù);
                c.生成的實(shí)體對象是VO對象,如果對這些對象調(diào)用Session的saveOrUpdate方法將導(dǎo)致插入新的記錄,而不是更新記錄。
          posted @ 2005-06-15 16:33 小米 閱讀(3001) | 評論 (0)編輯 收藏
                JBuilder 2005中多了一個(gè)Smart MemberInsight功能,這個(gè)功能會智能的匹配需要調(diào)用的方法或者獲取的屬性。例如有一個(gè)賦值操作,左邊是一個(gè)List,右邊是用一個(gè)方法獲取值,那么當(dāng)輸入"."時(shí),JBuilder 2005會自動的找到所有返回的值為List的方法。
                不過,這實(shí)在是一個(gè)不怎么討好的方法。因?yàn)楹芏鄷r(shí)候并不是只有一層方法調(diào)用的,例如,當(dāng)需要用一個(gè)方法獲取一個(gè)實(shí)例,然后再用這個(gè)實(shí)例的方法獲取需要的值時(shí),這個(gè)功能就顯得很礙手了。
                終于,我還是決定關(guān)閉這個(gè)“智能”的功能。打開"Tools"——>"Preferences",在"Editor"的子項(xiàng)"CodeInsight"里,展開"MemberInsight",把"Default to Smart MemberInsight"這一項(xiàng)去掉。如下圖所示:

          memberinsight.JPG
          posted @ 2005-06-15 16:02 小米 閱讀(526) | 評論 (0)編輯 收藏
          僅列出標(biāo)題
          共6頁: 上一頁 1 2 3 4 5 6 下一頁 
          主站蜘蛛池模板: 阿克| 无为县| 清流县| 镇赉县| 兖州市| 东源县| 泸西县| 新田县| 韩城市| 同江市| 曲阜市| 镇安县| 滨海县| 厦门市| 郑州市| 万载县| 淳安县| 晋州市| 南靖县| 宁河县| 平利县| 全州县| 永春县| 新竹市| 紫金县| 江源县| 滦南县| 陕西省| 丹东市| 新源县| 雷州市| 乌兰察布市| 宝清县| 离岛区| 柘荣县| 东阿县| 资阳市| 平安县| 竹北市| 库尔勒市| 萝北县|