• <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(){};
                };


             

            国产农村妇女毛片精品久久| 无码人妻少妇久久中文字幕 | 久久久青草久久久青草| 777久久精品一区二区三区无码| 久久九九久精品国产免费直播| 日本五月天婷久久网站| 97超级碰碰碰碰久久久久| 日本五月天婷久久网站| 久久99热国产这有精品| 日韩精品久久久久久久电影| 91久久九九无码成人网站| 久久丫忘忧草产品| 欧美久久久久久精选9999| 久久99精品久久只有精品 | 亚洲AV无码久久精品狠狠爱浪潮| 国内精品欧美久久精品| 欧美精品久久久久久久自慰| 久久国产精品无| 久久久久国产一区二区| segui久久国产精品| 国产精品99久久久久久人| 精品久久久无码21p发布| 中文精品久久久久人妻| 色婷婷久久久SWAG精品| 久久成人18免费网站| 成人午夜精品久久久久久久小说| 久久亚洲精品成人av无码网站| 久久精品国产亚洲AV忘忧草18| 青青草原综合久久大伊人导航| 精品国产综合区久久久久久| 久久免费精品视频| 99热成人精品免费久久| 久久AAAA片一区二区| 国内精品伊人久久久久影院对白 | 国内精品久久久久久久久电影网| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久精品国产精品青草 | 久久99国产精品久久99小说| 国产一区二区久久久| 青青草原综合久久大伊人| 国产成人综合久久精品红|