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

小明思考

高性能服務器端計算
posts - 70, comments - 428, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

對于性能優(yōu)化,相信喜歡C++的人都是比較重視效率。我準備寫一個系列,主要是基于我的一些實踐,至于理論上的東西,不是我的重點。我也講不出來一堆道理:-)。我所說的例子,都將是我以前所遇到的一些案例,記錄一下思路,拿出來跟大家share。


在C++程序中,自從有了STL,很少有人去自己去設計數(shù)據(jù)結(jié)構(gòu),當然大部分情況STL的效率都是可以的。萬事都有例外。

我接觸到一個需求,是根據(jù)手機號碼的號段表(位數(shù)不定,一般是七八位)來查出手機號碼所在的地區(qū)。
比如
1315156   南京
13812345 北京
1366789  上海
025          南京

一種可能的方案是設計多個hashmap
map<int,string> seg8; map<int,string> seg7;  map<int,string> seg3; ...
每個map分別對應不同的位數(shù)。對于一個phone,分別在這些map中查找
但是效率不行。

這里面有個關(guān)鍵,因為手機號碼都是數(shù)字,我們可以設計出一棵樹,每個節(jié)點都是0-9,他可以有10個節(jié)點,葉子節(jié)點我們就可以儲存數(shù)據(jù)。迅速在大腦里想象一個這樣的模型。

還是看代碼比較明了。 十叉樹

#if !defined __TREE10__
#define __TREE10__

#pragma warning(disable:
4786)

namespace sandy
{
    
namespace Private  
    {
        template
<class VALUE>
            
struct __Node10  //節(jié)點struct
        {
            typedef __Node10
<VALUE>* POINTER;
            VALUE 
* data; //數(shù)據(jù)
            POINTER ptr[10]; //子節(jié)點
            
            __Node10():data(
0)
            {
                memset(ptr,
0,sizeof(POINTER)*10);
            }
        };
    }
    
    template
<typename VALUE>
        
class CTree10
    {
        typedef  Private::__Node10
<VALUE> NODE;
    
private:
        
long                    m_lcount;          //插入的數(shù)據(jù)數(shù)量
        long                    m_lnodecount;      //節(jié)點數(shù)
        NODE*                    m_proot;           //根結(jié)點指針
        
    
public:
        CTree10():m_lcount(
0),m_lnodecount(0),m_proot(CreateNode()) //notice:Keep order with their declare
        {
        }
        
~CTree10()
        {
            DestroyAll();
        }
        
        
void DestroyAll()
        {
            
for(short i =0;i<10;++i)
            {
                
if(m_proot->ptr[i]!=0)
                {
                    Remove(m_proot
->ptr[i]);
                    m_proot
->ptr[i] = 0;
                }
            }
        }
        
        
bool Insert(const char*pKey,const VALUE &data) //插入節(jié)點
        {
            assert(pKey
!=0);
            NODE 
* pNode = m_proot;
            NODE 
* pChildNode =0;
            
char c = 0;
            
            
for(unsigned int i=0;i<strlen(pKey);++i)
            {
                c 
= pKey[i];    if(c<'0' || c>'9'return false;
                pChildNode 
= pNode->ptr[(c-'0')];
                
if(pChildNode == 0//not build
                {
                    pChildNode 
= pNode->ptr[(c-'0')] = CreateNode();//create a new child
                }
                pNode 
= pChildNode ;//change node to child node
            }
            
            
if(pNode->data == 0//empty 
            {
                pNode
->data = new VALUE(data);
                
++m_lcount;
                
return true;
            }
            
else//already inserted
            {
                
return false;
            }
        }
        
        
bool Lookup(const char*pKey,VALUE &data,bool strick = true)
        {
            assert(pKey
!=0);
            NODE 
* pNode = m_proot;
            NODE 
* pChildNode =0;
            
char c = 0;
            
            
for(unsigned int i=0;i<strlen(pKey);++i)
            {
                c 
= pKey[i]; if(c<'0' || c>'9'return false;
                pChildNode 
= pNode->ptr[(c-'0')];
                
if(pChildNode!=0)
                {
                    pNode 
= pChildNode;
                }
                
else // can't find
                {
                    
if(!strick)
                    {
                        
break;
                    }
                    
return false;
                }
            }
            
            
if(pNode->data != 0//already inserted
            {
                data 
= *(pNode->data);
                
return true;
            }
            
else  // no inserted
            {
                
return false;
            }
        }
        
    
private:
        NODE 
*CreateNode()
        {
            NODE 
*pNewNode = new NODE();
            assert(pNewNode
!= 0);
            
++m_lnodecount;
            
return pNewNode;
        }
        
        
void Remove(NODE *pNode)
        {
            assert(pNode
!=0);
            
forshort i = 0 ; i < 10 ; i ++ )
            {
                
if( pNode -> ptr[ i ] )
                    Remove( pNode 
-> ptr[ i ] );
            }
            
if(pNode->data!=0)
            {
                delete pNode
->data;
                
--m_lcount;
            }
            
--m_lnodecount;
            delete pNode;
        }
    };
}

#endif


這個Tree10我在vc6下測試的結(jié)果:
插入速度比std::map快3倍,查詢速度則是std::map的10倍


 

Feedback

# re: C++性能優(yōu)化實踐1---設計數(shù)據(jù)結(jié)構(gòu)  回復  更多評論   

2005-12-22 20:53 by 小明
C++性能優(yōu)化,我推薦一本比較好的書
Efficient C++ Performance Programming Techniques

# re: C++性能優(yōu)化實踐1---設計數(shù)據(jù)結(jié)構(gòu)  回復  更多評論   

2005-12-23 09:42 by ngaut
支持小明兄創(chuàng)作,建議多測試幾個stl的數(shù)據(jù),僅僅vc6恐怕還說明不了太多問題,不妨試試STL PORT 和 gcc的,以及vs.net自帶的stl

# re: C++性能優(yōu)化實踐1---設計數(shù)據(jù)結(jié)構(gòu)  回復  更多評論   

2005-12-23 16:45 by 小軟
love 小明
這個功能,我很久以前就聽你說過了,老一套,不是新聞是舊聞了:)

# re: C++性能優(yōu)化實踐1---設計數(shù)據(jù)結(jié)構(gòu)  回復  更多評論   

2006-01-05 10:36 by LEE
1.空間換時間,這樣做空間應該會大很多,而且所換回的效率也不見得怎么樣。
2.你的容器的Key是char*,而你用的stl map的key又是int,怎么不把你的容器的key換成int試下?
3.如果這個int的key是一個很大的數(shù)字呢?
4.這個int的數(shù)字你選擇是十進制的位來分解,那為什么不是其他進制的?
5.STL的map是用的RB二叉樹,相當于二分查找,算法復雜度為O(log2n),這個是為了考慮個別查詢的效率在控制范圍內(nèi)。如果要比查詢的平均時間的話,你要和hash算法比,使用STL的hash_map(雖然這個不在標準內(nèi),但是大多數(shù)STL還是支持的),算法復雜度為O(1),估計你的n分查找是很難比過的。

# re: C++性能優(yōu)化實踐1---設計數(shù)據(jù)結(jié)構(gòu)  回復  更多評論   

2006-01-05 10:42 by LEE
順便提一句,實際上大多數(shù)系統(tǒng)中的key-value pair算法都是使用hash算法。另外就是B樹了,這二者的查詢效率應該是最好的了。B樹在很多數(shù)據(jù)庫、文件系統(tǒng)中大量使用,基本上是樹型查找的極致了。

# re: C++性能優(yōu)化實踐1---設計數(shù)據(jù)結(jié)構(gòu)  回復  更多評論   

2006-01-18 08:13 by nanami
std::map使用的RB二叉樹(紅黑二叉樹,或平衡B樹),就是B樹的一個特殊情況。HashMap要分情況用,畢竟計算Hash是需要耗費一個恒定的時間,而同時為了避免Hash碰撞,需要一個算法比較復雜的HASH,這個一般只有在海量數(shù)據(jù)的時候優(yōu)勢才明顯,否則還不如MAP的效率。

# re: C++性能優(yōu)化實踐1---設計數(shù)據(jù)結(jié)構(gòu)  回復  更多評論   

2006-03-20 14:38 by alou
呵呵,當年我還用過256叉樹呢。

# re: C++性能優(yōu)化實踐1---設計數(shù)據(jù)結(jié)構(gòu)  回復  更多評論   

2006-05-15 15:26 by yhhv
好辦法!
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲第一视频| 欧美伊人久久久久久久久影院 | 欧美亚洲成人精品| 亚洲小说区图片区| 一本到高清视频免费精品| 国产精品久久久久久户外露出| 牛人盗摄一区二区三区视频| 亚洲欧洲另类| 日韩一区二区福利| 国内精品视频一区| 亚洲激情不卡| 国产精品户外野外| 美日韩在线观看| 欧美精品v国产精品v日韩精品| 亚洲手机成人高清视频| 性欧美暴力猛交另类hd| 亚洲国产欧美久久| 亚洲先锋成人| 精品成人一区二区三区四区| 亚洲精品一区二区三| 国产日韩在线视频| 亚洲国产精品99久久久久久久久| 国产精品v欧美精品∨日韩| 久久艳片www.17c.com| 久久久久久久高潮| 久久九九久精品国产免费直播 | 久久激情视频| 亚洲一区二区三区久久| 久久久噜噜噜久久中文字幕色伊伊 | 在线观看三级视频欧美| 亚洲少妇中出一区| 91久久精品一区二区别| 亚洲欧美国产制服动漫| 一区二区黄色| 久热精品视频在线观看一区| 午夜精品视频一区| 欧美日韩精品二区| 亚洲高清av| 亚洲成人影音| 欧美尤物巨大精品爽| 亚洲一区二区免费视频| 欧美黄色一区| 亚洲成人在线网| 一区二区亚洲精品国产| 亚洲女人天堂av| 亚洲欧美日韩精品久久久| 欧美成ee人免费视频| 免费h精品视频在线播放| 国产日韩欧美一区| 亚洲天天影视| 亚洲欧美成人一区二区在线电影| 欧美精品福利视频| 亚洲黄色免费网站| 欧美一区二区成人6969| 亚洲嫩草精品久久| 欧美特黄一级| aa级大片欧美三级| 亚洲在线免费视频| 国产精品xxxav免费视频| 夜夜嗨av一区二区三区免费区| 亚洲精品国产精品国产自| 欧美岛国激情| 亚洲精品影院| 亚洲亚洲精品三区日韩精品在线视频 | 亚洲国产婷婷| 亚洲国产精品一区二区第四页av | 亚洲国产日韩欧美一区二区三区| 亚洲国产美女| 欧美日韩成人一区| 一区二区三区视频免费在线观看| 亚洲特黄一级片| 国产精品久久久久久久久久久久 | 亚洲乱码国产乱码精品精| 亚洲美女视频网| 欧美视频免费| 亚洲午夜视频在线观看| 欧美午夜一区二区| 亚洲自拍三区| 免费成人激情视频| 亚洲精品美女久久久久| 欧美日韩综合| 亚洲综合电影一区二区三区| 久久精品一区| 亚洲日韩欧美视频一区| 欧美视频不卡| 欧美不卡一区| 欧美成人午夜视频| 日韩天堂在线观看| 欧美一区二区私人影院日本| 国产日韩综合| 欧美国产日韩一区二区| 国产精品99久久久久久久女警| 欧美一区激情| 亚洲黄色片网站| 国产精品视频久久久| 久久久人人人| 一区二区三区四区五区在线| 久久综合伊人77777| 亚洲私人影院在线观看| 精品av久久久久电影| 欧美日本在线看| 久久久久久久网| 亚洲香蕉视频| 国内欧美视频一区二区| 欧美日本国产精品| 久久久久免费观看| 一本大道久久精品懂色aⅴ | 亚洲自拍偷拍视频| 亚洲国产美女久久久久| 国产视频不卡| 欧美日韩系列| 欧美va亚洲va国产综合| 欧美亚洲专区| 亚洲视频高清| 日韩亚洲欧美一区| 欧美激情一区二区久久久| 久久精品国产一区二区电影| 亚洲亚洲精品三区日韩精品在线视频 | 久久综合电影| 欧美伊人久久久久久久久影院 | 久久精品国产精品| 亚洲女同在线| 在线亚洲自拍| 一本色道久久精品| 日韩视频二区| 狠狠色综合日日| 国产色综合久久| 国产日韩精品久久久| 国产精品免费在线| 国产精品久久久久免费a∨大胸| 欧美黑人国产人伦爽爽爽| 久久综合九色综合欧美就去吻| 欧美一区综合| 久久精品国产亚洲5555| 久久九九久精品国产免费直播| 午夜国产精品影院在线观看| 亚洲尤物视频网| 亚洲欧美日韩综合| 亚洲欧美一区二区激情| 午夜精品视频在线观看| 亚洲欧美第一页| 香港成人在线视频| 久久国产精品久久国产精品| 久久国产精品亚洲77777| 久久精品国产亚洲aⅴ| 久久噜噜亚洲综合| 免费在线播放第一区高清av| 欧美freesex8一10精品| 欧美日本乱大交xxxxx| 欧美色欧美亚洲高清在线视频| 国产精品白丝jk黑袜喷水| 国产乱子伦一区二区三区国色天香 | 亚洲国产成人久久综合一区| 欧美三区在线观看| 国产精品久久久久久福利一牛影视 | 久久成人资源| 欧美.www| 欧美色道久久88综合亚洲精品| 国产精品扒开腿爽爽爽视频| 国产视频久久久久| 亚洲国产成人精品女人久久久| 日韩视频在线观看| 亚洲欧美另类在线| 久热这里只精品99re8久| 亚洲福利视频一区| 亚洲一区二区欧美| 久久久噜噜噜久久中文字幕色伊伊 | 久久久综合视频| 欧美激情一区二区三区全黄| 国产精品久久久久久影视| 黄色欧美成人| 国产精品99久久不卡二区| 欧美专区日韩专区| 亚洲国产精品va| 午夜国产一区| 欧美欧美天天天天操| 国产综合在线看| 亚洲午夜视频在线观看| 国产视频一区二区在线观看 | 国产精品一区免费视频| 亚洲动漫精品| 性欧美激情精品| 亚洲国产高清一区二区三区| 亚洲免费人成在线视频观看| 美女精品在线| 国内免费精品永久在线视频| 在线视频日本亚洲性| 免费视频最近日韩| 亚洲一区观看| 欧美日韩精品免费看| 国产综合18久久久久久| 亚洲欧美日本国产专区一区| 嫩草国产精品入口| 欧美亚洲免费在线| 欧美午夜在线一二页| 亚洲精品国产精品乱码不99按摩 | 欧美在线视频网站| 在线视频精品一区| 欧美日韩免费观看一区| 亚洲国产一区二区三区a毛片 |