• <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>
            志氣天涯  
            大數(shù)據(jù)搜索,分布式服務(wù),模式設(shè)計(jì),系統(tǒng)架構(gòu)設(shè)計(jì)
            日歷
            <2011年1月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345
            統(tǒng)計(jì)
            • 隨筆 - 1
            • 文章 - 0
            • 評(píng)論 - 5
            • 引用 - 0

            導(dǎo)航

            常用鏈接

            留言簿

            隨筆檔案

            搜索

            •  

            最新評(píng)論

             

            2011年1月11日

              我們?cè)诔绦蜷_(kāi)發(fā)中,也許經(jīng)常碰到這樣的情況,在一個(gè)業(yè)務(wù)流程中會(huì)調(diào)用很多不同的函數(shù)。

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

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

            //----------------------------------------
                 而在上面三個(gè)函數(shù)中每個(gè)函數(shù)的內(nèi)部很可能都查詢?cè)L問(wèn)了同一個(gè)數(shù)據(jù),這樣就造成了資源的浪費(fèi),
            有沒(méi)有解決辦法呢?
                 我想了一個(gè)解決方法,我命名為“數(shù)據(jù)商店”。“數(shù)據(jù)商店”:從名字即可看出思路,在整個(gè)業(yè)務(wù)流程中創(chuàng)建一個(gè)二重hash表,先按類型做外層hash表的key,而后按每個(gè)對(duì)象關(guān)鍵字來(lái)做內(nèi)層hash表的key。用這種結(jié)構(gòu)把數(shù)據(jù)暫存起來(lái)以便業(yè)務(wù)流程中每個(gè)函數(shù)訪問(wèn)。那怎么在業(yè)務(wù)流程中的每個(gè)函數(shù)內(nèi)部訪問(wèn)呢?
            把存儲(chǔ)數(shù)據(jù)的二重hash表做為參數(shù)傳給每個(gè)函數(shù)。
            下面是偽代碼:
            //-----------------------------------------------------------------
            #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);
            //-----------------------------------------------------------------
            在每個(gè)函數(shù)中在訪問(wèn)請(qǐng)求數(shù)據(jù)前,都在shop中搜索要請(qǐng)求的數(shù)據(jù)在shop中是否存在,如果shop中存在就
            直接取出,不必再訪問(wèn)請(qǐng)求數(shù)據(jù)節(jié)省了資源和時(shí)間。
            這個(gè)解決方法只在一個(gè)業(yè)務(wù)流程中使用,不作為類似緩存或持久層來(lái)使用。請(qǐng)大家給些意見(jiàn),現(xiàn)在還沒(méi)有完善。




            posted @ 2011-01-11 15:58 sapielion 閱讀(1602) | 評(píng)論 (5)編輯 收藏
             
            Copyright © sapielion Powered by: 博客園 模板提供:滬江博客
            久久综合九色综合网站| 精品久久久久久无码中文野结衣| 亚洲国产婷婷香蕉久久久久久| 国产精品成人精品久久久| 99久久综合国产精品二区| 久久久精品国产亚洲成人满18免费网站| 亚洲国产天堂久久综合| av国内精品久久久久影院| 国产免费久久精品99久久| 亚洲AV无码久久精品色欲| 66精品综合久久久久久久| 无码人妻精品一区二区三区久久 | 中文成人久久久久影院免费观看| 国产亚洲精久久久久久无码77777| 国产精品99久久99久久久| 久久精品极品盛宴观看| 久久国产精品无码网站| 成人资源影音先锋久久资源网| 国内精品久久久久影院薰衣草 | 久久久久久久波多野结衣高潮| 亚洲伊人久久大香线蕉苏妲己| 久久久无码精品亚洲日韩蜜臀浪潮| 久久久精品波多野结衣| 欧美伊香蕉久久综合类网站| 精品人妻久久久久久888| 亚洲精品无码久久久久久| 久久亚洲国产精品成人AV秋霞| 久久人人爽人人爽人人片AV麻豆 | 久久久久人妻一区二区三区| 欧美精品一区二区久久| 久久99精品国产麻豆不卡| 999久久久国产精品| 亚洲综合久久综合激情久久| 亚洲狠狠综合久久| 国产精品欧美亚洲韩国日本久久 | 国产美女久久精品香蕉69| 久久亚洲精精品中文字幕| 亚洲日本va中文字幕久久| 亚洲精品无码成人片久久| 无码人妻精品一区二区三区久久久 | 国产高潮国产高潮久久久91 |