麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

Jive筆記--Database Package下面的暗黑世界

2019-11-18 13:26:36
字體:
來源:轉載
供稿:網友

  Jive再牛B,歸根到底還是要和Database打交道的。
  還不一樣要調用getConnection(),CreateStatement(),ResultSet.next()。
  那么,我的疑問是,Jive是怎樣處理低層操作類(DBForumMessage/DBForumThread/DBForum)之間的耦合關系的呢?
  由于存在了Cache,所以,DBForumFactory/DBCacheManager/DBForumXXX這些類之間的關系可謂是錯綜復雜。
  
  (1)真正實作中,我們怎樣來完成加載一個ForumMessageObject? 還有thread的增加刪除Message是怎樣完成的?
  打開DBForumMessage.java,發現,除了完成ForumMessage Interface的方法以外,還有幾個PRivate的方法和Protected的方法。
  分別是:
  private void loadFromDb();
  private void saveToDb();
  protected void insertIntoDb();等
  
  上面三個函數分別用來完成對jiveMessage表的SELECT/UPDATE/INSERT操作。
  所以初步可以判定,對jiveMessage表的操作,基本上封裝在了DbForumMessage里邊了。但不是全部,為什么?慢慢往下看。
  
  a.加載DbForumMessage
  非常簡單,地球人都知道的代碼。在一個構造函數中調用loadFromDb(),然后執行SELECT xxx,xxx,..WHERE id=...,假如rs為空則拋出
  MessageNotFoundException,否則,一個一個的把字段內容復制給DBForumMessage的成員變量。
  (順便這里提一下,這些映射數據庫字段的成員變量有些是Private的,有些是Protected,為什么呢?呵呵。)
  對于這樣的加載方法,假如沒有Cache,將會非常慢的。試想,每次顯示一個Message都要一次Select,我瀏覽Thread頁面的時候,一次顯示n個Thread/Message,....
  還不要數據庫的小命啊。
  
  在我克隆Jive的過程中,由于Cache機制將在以后實現,所以采取了一個折衷的辦法。改寫了DBMessageIterator()類,改原來的只取ID
  為 取回除了Body以外的所有的內容,并且 直接就地New DBForumMessage,然后復制到ArrayList。
  至于Body,則采用LazyLoad的方法,等用到了才去SELECT body FROM ...
  這樣處理,由于有ResultFilter的限制,最多復制幾十個沒有Body的DBForumMessag 對象,這對于AppServer來說,我想影響不大吧?
  
  b.增加DBForumMessage
  也就是調用INSERT INTO jiveMessage啦。不過,注重到,在插入新的ForumMessage紀錄的時候,ThreadID是必須的,
  所以看起來只能讓DBForumThread來調用這個方法了。難怪!!用了protected insertIntoDb(DbForumThread)!! 原來,同在一個包下的class是
  可以互相訪問protected的方法的。偶java基本功不行,呵呵,到了今天才發現的這種現象。
  
  c.刪除DBForumMessage
  這個比較有趣,DBForumMessage沒有任何執行DELETE FROM jiveMessage的代碼,看起來一定是在外邊DBThread實現了。
  究竟,這個是thread的事情嘛。果不出所料,DbForumThread::deleteMessage()里邊直接執行了DELETE SQL.
  我自己在Clone Jive的時候,還是作了小改動,給DbForumMessage添加了protected deleteFromDb()方法,把執行SQL的操作放給Message完成了。
  
  在對Message進行Add/Delete操作過程中,可不能忘記了Cache List的更新,所以必須記得在DbForumMessage中調用cacheManager的一些方法
  來更新Cache,雖然目前在我的系統中,這些函數是空的 :)。
  
  明白了Thread/Message之間的"父子關系",Forum/Thread Category/Forum之間的關系也就差不多啦。哦,Jive中的Category似乎有點非凡,
  等偶下次看了代碼再另外具體匯報。
  
  (2)DBForumFactory是個什么東西?
  Jive2.1.1以后,DbForumFactory不給Source了,而且,JAD還很難反編譯,因為我發現JAD無法反編譯諸如synchronized(Object){}這樣的代碼。
  還好我們有Jive 2.1.1的代碼。哈哈。看看再說。
  先把DBForumFactory的身份給揭穿。其實DbForumFactory是個總管。總管Forum/Thread/Message。
  所以,我們在調用API的時候,都是通過Factory.getForum()/getThread()/getMessage()來獲得那些對象。
  Jive用了SingleTon保證DbForumFactory()唯一,即靜態方法DbForumFactory.getInstance()。
  同時,DBForumFactory在構造函數中New了一個DatabaseCacheManager。因此Factory和CacheManager就這樣勾結起來了。
  所有調用getForum(),getThread(),getMessage(),都是調用DatabaseCacheManager的相關方法來實現的。
  例:
  
  DBForumFactory::getThread() ==> DatabaseCacheManager.getThread() ==> Search Cache or new DbThread object
  
  結論,DbForumFactory不是東西。除了檢測Licese是否合法,其它基本上就是一個二道販子。
  
  (3)其實還有那些Thread/Message的DbIterator,在Jive筆記4中已經提到了。不必再羅嗦一遍。
  
  寫了這么多,感覺還有好多東西沒有講。我希望大家能夠仔細體味里邊的protected 屬性/方法,我認為,這些東西其實和友元差不多,
  它們部分的打破了封裝,但是獲得了很大的靈活性。
  退后一步想想,我們只要把那些東西一股腦兒的限制在database package里邊,對于整體上的封裝,還是沒有什么影響的。
  
  呵呵,一家之言,請大家不吝指教

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久国产精品区 | 91麻豆蜜桃一区二区三区 | 国产成人av在线播放 | 久久www视频 | 久久精品在线免费观看 | 中国女人内谢8xxxxxx在 | 在线观看91精品 | 欧美人与性禽动交精品 | 特大黑人videos与另类娇小 | 成人情欲视频在线看免费 | 91九色精品 | 欧美 日韩 亚洲 中文 | 一级性色| 久久国产不卡 | 中文字幕在线永久视频 | 一级黄色毛片免费 | av在线中文 | 日本在线视频免费 | 久久精品免费网站 | 成码无人av片在线观看网站 | 免费午夜网站 | 欧美一级毛片欧美一级成人毛片 | 欧美精品久久久久久久久老牛影院 | 久久久鲁| 欧美大电影免费观看 | 369看片你懂的小视频在线观看 | 亚洲一区在线免费视频 | 日本在线不卡一区二区 | 欧美一级做性受免费大片免费 | 久久精品亚洲一区二区 | 国产成年人在线观看 | 91精品国产日韩91久久久久久360 | 欧美日韩在线播放 | 久久久精品视频国产 | 人人玩人人爽 | 成人一级黄色片 | 国产乱色精品成人免费视频 | 欧美精选一区二区 | 中文字幕国产日韩 | 激情综合视频 | 国产亚洲精品影达达兔 |