青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運轉,開心的工作
簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

排序比較函數:<符號你重載對么了么?

Posted on 2011-10-15 08:00 S.l.e!ep.¢% 閱讀(808) 評論(0)  編輯 收藏 引用 所屬分類: C++
前段時間整理臺歷的邏輯數據時考慮到需要去兼容已發布的照片書數據,很多地方做了兼容處理,比如下面這個例子:

????? 在很多時候,我們常常會使用map儲存一些需要經常查詢數據結構,而map的key在一開始設計的時候往往不多加思索,很容易就認為它就是個純ID,比如一個數字,或者一個字符串。當隨著產品變得復雜,或者不同數據結構的添加,這個假設往往不堪一擊—-比如在網游中的游戲ID竟然被認為是唯一的Key,而實際上如果涉及到服務器合并,這個ID也就不那么唯一了。很顯然需要解決這個問題就是擴充原來的Key:要么還是將附加信息直接和原先的Key合并,要么將它倆合并到一個數據結構中—-而后者會引來一個小問題:

?????? 如果我把這個Key儲存在某個有序容器中,我就需要重新告訴他各個key是按照什么順序排序的。

????? 在做照片書的時候,服務器告訴你:哦,我們的模板ID就是唯一標識了,你拿這個ID就可以得到我這邊關于這個作品的所有數據。而到了做臺歷的時候,服務器換了種說法:不好意思,為了充分利用資源,我們很多臺歷用得是同一個模板,你還要告訴我這個臺歷的產品ID。于是shit就這么發生了。

?????? 可憐的Key就從string templateID,變成了struct TemplateKey{string m_sTemplateID;string m_sProductID};嗯,這不是什么問題,比較煩的就是如果你用map來儲存,那你就得自己重寫排序比較函數,于是你有了如下的代碼:

1booloperator<(constTemplateSearchKey &searchKey) const
2{
3????????returnm_sProductID < searchKey.m_sProductID &&
4???????????????m_sTemplateID < searchKey.m_sTemplateID;
5}

可惜的是這樣的代碼大錯特錯,試試下面的代碼

01#include <iostream>
02#include <map>
03#include <string>
04??
05usingnamespacestd;
06??
07structTemplateSearchKey
08{
09????string m_sProductID;
10????string m_sTemplateID;
11????TemplateSearchKey(conststring& sTemplateID,conststring& sProductID)
12????{
13????????m_sTemplateID??? = sTemplateID;
14????????m_sProductID??? = sProductID;
15????}
16??
17????booloperator<(constTemplateSearchKey &searchKey) const
18????{
19????????returnm_sProductID < searchKey.m_sProductID &&
20???????????????m_sTemplateID < searchKey.m_sTemplateID;
21????}
22};
23??
24intmain()
25{
26????map<TemplateSearchKey,string> testMap;
27????TemplateSearchKey key("","2");
28????TemplateSearchKey key1("","1");
29????TemplateSearchKey key2("","3");
30????testMap[key] = "a";
31????testMap[key1] = "b";
32????testMap[key2] = "c";
33????cout<<testMap[key]<<endl;
34????system("pause");
35????return0;
36??
37}

做調整:

1booloperator<(constTemplateSearchKey &searchKey) const
2{
3??
4???????returnm_sProductID < searchKey.m_sProductID ||
5??????????????m_sTemplateID < searchKey.m_sTemplateID;
6??
7}

?

而這個連編譯都是不通過的……出一個ASSERT告訴你你的<符號是無效的。

01template<class_Pr, class_Ty1, class_Ty2> inline
02bool__CLRCALL_OR_CDECL _Debug_lt_pred(_Pr _Pred, const_Ty1& _Left, const_Ty2& _Right,
03??
04????constwchar_t*_Where, unsigned int_Line)
05??
06{??? // test if _Pred(_Left, _Right) and _Pred is strict weak ordering
07??
08if(!_Pred(_Left, _Right))
09??
10????return(false);
11??
12elseif(_Pred(_Right, _Left))
13??
14????_DEBUG_ERROR2("invalid operator<", _Where, _Line); //ASSERT出來的點
15??
16return(true);
17??
18}

于是趕緊琢磨了下,改了:

01booloperator<(constTemplateSearchKey &searchKey) const
02{
03??
04????if(m_sProductID == searchKey.m_sProductID)
05????{
06????????returnm_sTemplateID < searchKey.m_sTemplateID;
07????}
08????else
09????{
10????????returnm_sProductID < searchKey.m_sProductID;
11????}
12};

OK,編譯通過,運行沒問題。可問題也來了,如果有3個成員呢?4個5個呢?一個比較好的方法就是直接把每個成員hash成一個數值,然后各個數值鏈起來,通過比較最后這個值來確定大小。于是就想了,為啥不學JAVA直接把排序功能切成兩部分—-兩個函數hasCode和equals,一個用來確定東西怎么排序,而另外一個用來確定是不是同一個東西。而STL這種做法雖然簡練卻晦澀,需要用戶自己去考慮我寫完的排序函數是不是符合傳說中的排序三定律(有時候即使符合也不能完全反應用戶原意)。

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲在线观看视频| 欧美成人免费大片| 国产在线不卡| 亚洲盗摄视频| 欧美日韩中文在线观看| 欧美在线网址| 99视频精品全国免费| 尤物精品国产第一福利三区 | 亚洲精品中文在线| 国内精品视频在线播放| 欧美一区三区三区高中清蜜桃| 蜜月aⅴ免费一区二区三区| 久久gogo国模裸体人体| 国产精品二区二区三区| 亚洲国产一区视频| 亚洲高清不卡在线观看| 欧美制服丝袜第一页| 午夜在线成人av| 欧美日韩亚洲一区二区三区在线观看 | 亚洲第一精品在线| 影音先锋日韩资源| 久久精品日产第一区二区| 久久电影一区| 国产无遮挡一区二区三区毛片日本| 亚洲一区二区高清| 亚洲欧美日韩网| 国产精品日韩在线播放| 亚洲四色影视在线观看| 亚洲欧美日韩在线不卡| 国产精品伦理| 亚洲综合色丁香婷婷六月图片| 亚洲资源av| 国产精品久久久一区麻豆最新章节| 亚洲国产精品久久久久秋霞不卡| 香蕉av福利精品导航| 亚洲视频网站在线观看| 一本大道久久a久久综合婷婷| 亚洲高清免费视频| 亚洲黑丝一区二区| 欧美日韩国产成人精品| 亚洲欧洲日本专区| 亚洲三级免费电影| 欧美日韩成人在线| 一区二区三区免费看| 欧美一区二区在线免费观看| 国产午夜精品久久久久久久| 久久久久**毛片大全| 欧美黑人国产人伦爽爽爽| av成人天堂| 国产精品久久国产三级国电话系列| 亚洲欧美在线播放| 欧美暴力喷水在线| 亚洲视频精选在线| 国产一区二区精品久久| 免费欧美电影| 亚洲一区二区三区免费在线观看| 久久久久久亚洲精品中文字幕 | 99精品视频免费观看| 欧美日韩亚洲综合一区| 亚洲欧美一区在线| 欧美激情在线狂野欧美精品| 亚洲男人第一网站| 亚洲国产高清aⅴ视频| 欧美午夜一区二区福利视频| 久久久视频精品| 欧美好骚综合网| 久久久久欧美| 亚洲裸体俱乐部裸体舞表演av| 国产精品乱码妇女bbbb| 狂野欧美激情性xxxx欧美| 亚洲图片欧美一区| 欧美激情2020午夜免费观看| 欧美一区午夜精品| 日韩小视频在线观看专区| 国产一区二三区| 国产精品h在线观看| 久热这里只精品99re8久| 午夜精品久久一牛影视| 亚洲美女免费视频| 欧美国产视频在线观看| 久久九九免费视频| 一区二区三区免费看| 亚洲黄色影院| 在线播放亚洲一区| 国产午夜一区二区三区| 国产精品国产a| 欧美激情一二区| 久久精品91| 亚洲欧美国产日韩中文字幕| 亚洲精品欧美日韩| 麻豆精品传媒视频| 久久精品视频播放| 欧美亚洲一区二区在线观看| 在线视频亚洲一区| 亚洲每日更新| 91久久午夜| 亚洲国产激情| 黄色综合网站| 国产主播一区二区三区四区| 国产欧美精品久久| 国产精品久久久| 欧美日韩一区二区在线观看| 欧美日韩精品免费看| 欧美成人亚洲成人日韩成人| 麻豆精品国产91久久久久久| 久久午夜视频| 鲁鲁狠狠狠7777一区二区| 久久久一本精品99久久精品66| 久久精品一区二区三区中文字幕 | 欧美视频网址| 欧美日韩1区| 欧美日韩中文字幕| 国产精品二区二区三区| 国产精品欧美久久| 国产精品乱人伦一区二区| 国产精品一二三四区| 国产欧美视频在线观看| 国产一区二区三区免费不卡| 精久久久久久| 亚洲国产女人aaa毛片在线| 亚洲伦理在线观看| 亚洲天堂成人在线视频| 午夜精品久久久久久久99水蜜桃 | 亚洲一区二区精品在线观看| 亚洲天天影视| 欧美一区2区三区4区公司二百| 欧美在线一区二区| 老妇喷水一区二区三区| 欧美激情女人20p| 亚洲免费观看视频| 亚洲无限av看| 久久久五月婷婷| 欧美连裤袜在线视频| 国产精品免费久久久久久| 狠狠色狠色综合曰曰| 亚洲免费观看在线视频| 亚洲综合精品一区二区| 久久人人97超碰国产公开结果 | 国产综合久久久久影院| 亚洲国产成人久久综合| 中文高清一区| 久久免费视频网站| 亚洲欧洲日本mm| 亚洲免费一级电影| 免播放器亚洲一区| 国产精品网站在线播放| 亚洲激情电影在线| 亚洲欧美日韩在线高清直播| 免费观看日韩av| 一区二区三区四区五区视频| 久久精品国产视频| 欧美视频一区二区三区| 在线观看国产欧美| 亚洲一区网站| 亚洲第一偷拍| 欧美在线影院| 国产精品高潮久久| 亚洲国产欧美精品| 久久精品五月婷婷| 亚洲人成高清| 久久精品中文| 国产精品无人区| 这里只有精品视频| 欧美搞黄网站| 久久久久.com| 国产美女诱惑一区二区| 99精品热6080yy久久| 免费试看一区| 欧美在线91| 国产精品一区二区在线| 日韩写真视频在线观看| 久热这里只精品99re8久| 亚洲一区二区三区四区五区黄 | 国产精品久久一区二区三区| 亚洲精品少妇30p| 老**午夜毛片一区二区三区| 性色av香蕉一区二区| 国产精品久久久久久久久免费| 日韩亚洲欧美成人一区| 亚洲成人在线视频播放 | 欧美日韩在线精品| 亚洲美女毛片| 亚洲国产精品国自产拍av秋霞| 久久精品二区三区| 国产伪娘ts一区| 欧美一站二站| 亚洲私人黄色宅男| 国产精品v欧美精品v日韩| 一区二区三区蜜桃网| 亚洲精选一区| 欧美日韩亚洲激情| 在线中文字幕日韩| 亚洲日本欧美| 欧美区在线播放| 夜夜嗨av一区二区三区四区 | 麻豆精品一区二区av白丝在线| 欧美在线观看网站| 激情成人av| 欧美激情视频在线播放| 免费观看成人鲁鲁鲁鲁鲁视频 |