• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            志氣天涯  
            大數據搜索,分布式服務,模式設計,系統架構設計
            日歷
            <2011年1月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345
            統計
            • 隨筆 - 1
            • 文章 - 0
            • 評論 - 5
            • 引用 - 0

            導航

            常用鏈接

            留言簿

            隨筆檔案

            搜索

            •  

            最新評論

             
              我們在程序開發中,也許經常碰到這樣的情況,在一個業務流程中會調用很多不同的函數。

                例如:
            //---------------------------------------
                func1(param1);

                func2(param21,param22);
               
                func3(param31,param32,param33);

            //----------------------------------------
                 而在上面三個函數中每個函數的內部很可能都查詢訪問了同一個數據,這樣就造成了資源的浪費,
            有沒有解決辦法呢?
                 我想了一個解決方法,我命名為“數據商店”。“數據商店”:從名字即可看出思路,在整個業務流程中創建一個二重hash表,先按類型做外層hash表的key,而后按每個對象關鍵字來做內層hash表的key。用這種結構把數據暫存起來以便業務流程中每個函數訪問。那怎么在業務流程中的每個函數內部訪問呢?
            把存儲數據的二重hash表做為參數傳給每個函數。
            下面是偽代碼:
            //-----------------------------------------------------------------
            #include <map>
            #include <string>

            using namespace std;

            typedef struct DataNode
            {
               string type;
               map<string,void*> goods;
            } Chest;

            map<string,Chest> shop;

            func1(param1,&shop);

            func2(param21,param22,&shop);
                
            func3(param31,param32,param33,&shop);
            //-----------------------------------------------------------------
            在每個函數中在訪問請求數據前,都在shop中搜索要請求的數據在shop中是否存在,如果shop中存在就
            直接取出,不必再訪問請求數據節省了資源和時間。
            這個解決方法只在一個業務流程中使用,不作為類似緩存或持久層來使用。請大家給些意見,現在還沒有完善。




            posted on 2011-01-11 15:58 sapielion 閱讀(1599) 評論(5)  編輯 收藏 引用
            評論:
            • # re: 我在程序模式設計上的一個想法不知道算不算一個模式  doyle Posted @ 2011-01-11 16:57
              這是個緩存的思路
              不過,請解決數據更新問題
              如果數據庫里的值更新了,你這個二維hash表要怎么更新呢
              先查詢一次,判斷是不是更新了?
              那還是直接查詢吧  回復  更多評論   

            • # re: 我在程序模式設計上的一個想法不知道算不算一個模式  gbb21 Posted @ 2011-01-11 17:05
              這個不是山寨cache么?不過cache做得比你這個更加完善,首先,cache是隱式的,不需要額外的變量,其次cache很好解決了聲明周期控制,并發訪問控制等在你這很難解決的問題。  回復  更多評論   

            • # re: 我在程序模式設計上的一個想法不知道算不算一個模式  不得不過來回復一下 Posted @ 2011-01-11 21:21
              不得不過來回復一下

              如果這個數據商店是唯一的,那么可以做成全局靜態變量,完全不需要用參數

              另外,如果你的程序運行在一個容器中,比如servlet,EJB之類的,完全可以將這個數據商店托管給容器來處理,比如綁定到JNDI,你這個想法太簡單了,不能做為模式。
                回復  更多評論   

            • # re: 我在程序模式設計上的一個想法不知道算不算一個模式  jmchxy Posted @ 2011-01-12 10:39
              另外,如果這一系列函數和那個數據都是和某個問題相關的,可以把這些函數和數據封裝到類中,數據直接是類的成員,也不需要顯式提供一個單獨的參數,還可防止數據被其他函數錯誤修改。  回復  更多評論   

            • # re: 我在程序模式設計上的一個想法不知道算不算一個模式  finalday Posted @ 2011-01-13 13:25
              這個模式應用得很廣泛。一說cache大家都知道了。
              不是gof里面的模式,但一般情況下其實比那些模式更常用。
              不建議自己實現,有太多好實現了。
                回復  更多評論   

             
            Copyright © sapielion Powered by: 博客園 模板提供:滬江博客
            国产精品一久久香蕉产线看| 国产福利电影一区二区三区久久久久成人精品综合 | 狠狠久久亚洲欧美专区| 久久亚洲精精品中文字幕| 亚洲AV无码一区东京热久久| 日本精品一区二区久久久| 亚洲精品无码久久不卡| 狠狠色丁香久久婷婷综合| 热re99久久精品国99热| 国产2021久久精品| 伊人久久大香线蕉综合热线| 一本久道久久综合狠狠躁AV| 青春久久| 99精品国产在热久久无毒不卡| 狠色狠色狠狠色综合久久| 久久久久久亚洲精品无码| 久久99九九国产免费看小说| 久久99热这里只有精品66| 国内精品伊人久久久久AV影院| 国产99久久九九精品无码| 亚洲乱码日产精品a级毛片久久| 国产成人无码精品久久久性色| 色欲综合久久中文字幕网| 国产精品美女久久久久网| 久久久久亚洲AV成人网人人网站| 伊人久久大香线蕉AV一区二区 | 久久久久久久久波多野高潮| 国产69精品久久久久观看软件| 久久久国产精品亚洲一区| 伊人久久大香线蕉精品| 亚洲午夜久久久久妓女影院| 久久精品人人做人人爽电影| 狠狠88综合久久久久综合网 | 久久精品国产亚洲AV影院| 成人亚洲欧美久久久久| 久久精品国产精品亚洲毛片| 国产巨作麻豆欧美亚洲综合久久 | 久久精品国产亚洲AV久| 久久久久这里只有精品| 久久久久久久尹人综合网亚洲| 久久久亚洲AV波多野结衣|