• <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ù)的順序將不同于你插入時候的順序, 例子如下:

             

            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;

            }

             

            輸出的順序將是:

             

            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ù)插入時候的順序了。
            結論:這種方法只適合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(){};
                };


             

            99久久亚洲综合精品网站| 国产精品中文久久久久久久| 久久精品青青草原伊人| 久久久久亚洲AV成人网人人网站| 久久国产精品免费| 亚洲综合久久夜AV | 无码国内精品久久人妻| 久久久久久久尹人综合网亚洲| 欧美日韩中文字幕久久伊人| 久久精品无码一区二区三区日韩| 香蕉久久夜色精品国产2020| 久久香综合精品久久伊人| 欧美亚洲国产精品久久蜜芽| 四虎亚洲国产成人久久精品| 久久久久亚洲精品无码蜜桃| 午夜视频久久久久一区 | 久久久久人妻一区精品| 国产精品乱码久久久久久软件| 久久99亚洲网美利坚合众国| 思思久久99热只有频精品66| 精品国产福利久久久| 伊人久久综合无码成人网| 国产亚洲成人久久| 久久99精品久久只有精品| 狠狠色丁香久久婷婷综合| 少妇久久久久久被弄到高潮| 狠狠人妻久久久久久综合蜜桃| 久久婷婷国产综合精品 | 亚洲欧美日韩中文久久| 久久影院午夜理论片无码 | 久久久青草青青亚洲国产免观| 精品一二三区久久aaa片| 久久精品这里只有精99品| 亚洲午夜精品久久久久久人妖| 久久久噜噜噜www成人网| 无码伊人66久久大杳蕉网站谷歌| 久久99热这里只有精品66| 日韩人妻无码一区二区三区久久99 | 99久久精品国产综合一区| 狠狠狠色丁香婷婷综合久久俺| 久久国产精品成人片免费|