• <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>
            posts - 311, comments - 0, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            我們知道,在向map中插入數(shù)據(jù)對時候,map中的元素將按照一定的順序被插入到對應的節(jié)點上,換句話說,從map的頭開始順序地讀取數(shù)據(jù),其數(shù)據(jù)的順序?qū)⒉煌谀悴迦霑r候的順序, 例子如下:

             

            std::map<double,int> dnMap;

             

            dnMap[10.0] = 1;

            dnMap[2.9] = 2;

            dnMap[20.4] = 3;

             

            std::map<double,int>::iterator it = dnMap.begin();

            for(; it != dnMap.end();++it)

            {

            std::pair<double,int> _p = *it;

            std::cout <<"Key =" <<_p.first<<" Value = "<< _p.second<< endl;

            }

             

            輸出的順序?qū)⑹牵?/p>

             

            Key = Value =

             

            2.9 2

            10.0 1

            20.4 3

             

            如果map的鍵是用戶自定義的類型T,那么你還必須在T中實現(xiàn)比較運算符,至于具體的細節(jié)這里就不說了。

             

            但是如果你覺得map對你很合適,但是就是希望插入map中的數(shù)據(jù)保持最初插入時候的順序,這時候怎么辦?

             

            讓我們來看看stl中map的 聲明形式 (http://www.sgi.com/tech/stl/Map.html

             

            map<Key, Data, Compare, Alloc>

             

            注意第三個參數(shù)

            Compare : The key comparison function, a Strict Weak Ordering whose argument type is key_type; it returns true if its first argument is less than its second argument, and false otherwise. This is also defined as map::key_compare.

             

            其作用就是比較Key的大小,按照一定的順序確定map節(jié)點的順序,我們當然就可以定制這個函數(shù)對象以實現(xiàn)我們想要的的排序規(guī)則。

             

            好了,廢話說了不少,我的做法是

             

            template<class T>
            struct DisableCompare :public std::binary_function<T,T,bool>
            {
            bool operator()(T lhs,T rhs) const
            {
            return true;
            }
            };

             

             

            這樣來使用定制化的map :

             

            std::map<double,int,DisableCompare<double> > sMap;
            sMap[10.9] = 1;
            sMap[3.5] = 2;
            sMap[30.0] = 3;
            sMap[2.4] = 4;

             

            就可以保持數(shù)據(jù)插入時候的順序了。
            結(jié)論:這種方法只適合int,double數(shù)值為Key的情況,字符串的情況不行,最后用Vector解決,方法如下:

                typedef std::pair  <WE::String,   WE::String>              SqlPair;   
                typedef std::vector
            <std::pair<WE::String, WE::String > >  SqlBaseVector;

               
            class SqlVector : public SqlBaseVector
               {
               
            public:
                   
            void  push_back  (const SqlPair& sqlPair);
                   
            void  push_back  (const WE::String& sql, const  WE::String& tableName);

                   SqlVector(){};
                   
            ~SqlVector(){};
               };

                
            class SqlMap : public SqlVector
                {     
                
            public:
                    
            const WE::String& get_element(const WE::String& key);
                    
            void  set_element(const WE::String& key, const  WE::String& value);
                    SqlMap(){};
                    
            ~SqlMap(){};
                };


             

            久久久久久青草大香综合精品| 亚洲婷婷国产精品电影人久久| 色综合久久中文字幕综合网| 久久久久国色AV免费看图片| 青青青国产精品国产精品久久久久| 精品免费久久久久久久| 99久久精品九九亚洲精品| 欧美久久天天综合香蕉伊| 色综合久久久久综合99| 97精品伊人久久久大香线蕉 | AV狠狠色丁香婷婷综合久久| 99久久国产综合精品五月天喷水| 国产69精品久久久久777| 久久国产精品无码网站| 久久久久九国产精品| 国产精品一区二区久久精品涩爱| 久久久久一区二区三区| 久久艹国产| 久久99热精品| 久久久婷婷五月亚洲97号色| 久久夜色精品国产www| 久久精品无码专区免费青青| 久久久久久久综合日本亚洲| 四虎亚洲国产成人久久精品| 久久精品人人做人人妻人人玩| 99热成人精品热久久669| 色综合久久中文字幕综合网| 久久久亚洲欧洲日产国码aⅴ| 国産精品久久久久久久| 婷婷久久久亚洲欧洲日产国码AV | 国色天香久久久久久久小说| 久久这里只有精品久久| 久久免费看黄a级毛片| 色综合久久最新中文字幕| 亚洲精品无码久久久| 伊人久久综在合线亚洲2019| 久久人人爽人人爽人人片AV不 | 久久久噜噜噜久久中文福利| 人妻中文久久久久| 亚洲综合精品香蕉久久网97| 午夜精品久久久久久久久|