女人被狂躁到高潮视频免费无遮挡,内射人妻骚骚骚,免费人成小说在线观看网站,九九影院午夜理论片少妇,免费av永久免费网址

當(dāng)前位置:首頁 > > 充電吧
[導(dǎo)讀]LevelDB中的skiplist實現(xiàn)方式基本上和中的實現(xiàn)方式類似。它向外暴露接口非常簡單,如下:public: ??//?Create?a?new?SkipList?object?that?will

LevelDB中的skiplist實現(xiàn)方式基本上和中的實現(xiàn)方式類似。它向外暴露接口非常簡單,如下:

public:
??//?Create?a?new?SkipList?object?that?will?use?"cmp"?for?comparing?keys,
??//?and?will?allocate?memory?using?"*arena".??Objects?allocated?in?the?arena
??//?must?remain?allocated?for?the?lifetime?of?the?skiplist?object.
??explicit?SkipList(Comparator?cmp,?Arena*?arena);

??//?Insert?key?into?the?list.
??//?REQUIRES:?nothing?that?compares?equal?to?key?is?currently?in?the?list.
??void?Insert(const?Key&?key);

??//?Returns?true?iff?an?entry?that?compares?equal?to?key?is?in?the?list.
??bool?Contains(const?Key&?key)?const

private成員變量:


private:
??enum?{?kMaxHeight?=?12?};

??//?Immutable?after?construction
??Comparator?const?compare_;
??Arena*?const?arena_;????//?Arena?used?for?allocations?of?nodes

??Node*?const?head_;

??//?Modified?only?by?Insert().??Read?racily?by?readers,?but?stale
??//?values?are?ok.
??port::AtomicPointer?max_height_;???

??//?Read/written?only?by?Insert().
??Random?rnd_;

一.構(gòu)造函數(shù)

templateSkipList::SkipList(Comparator?cmp,?Arena*?arena)
????:?compare_(cmp),
??????arena_(arena),
??????head_(NewNode(0?/*?any?key?will?do?*/,?kMaxHeight)),
??????max_height_(reinterpret_cast(1)),
??????rnd_(0xdeadbeef)?{
??for?(int?i?=?0;?i?<?kMaxHeight;?i++)?{
????head_->SetNext(i,?NULL);
??}
}

重點注意下head_和rnd_的初始化,NewNode方法如下。

templatetypename?SkipList::Node*
SkipList::NewNode(const?Key&?key,?int?height)?{
??char*?mem?=?arena_->AllocateAligned(
??????sizeof(Node)?+?sizeof(port::AtomicPointer)?*?(height?-?1));
??return?new?(mem)?Node(key);
}

這里為什么是“height-1”詳見:LevelDb源碼分析之五:skiplist(1)。


new (mem) Node(key)使用了placement new技巧,詳見:C++中使用placement new

rnd_是一個Random類型的變量,使用0xdeadbeef進(jìn)行初始化,Random詳見LevelDB源碼分析之七:Random

二.插入函數(shù)


templatevoid?SkipList::Insert(const?Key&?key)?{
??//?TODO(opt):?We?can?use?a?barrier-free?variant?of?FindGreaterOrEqual()
??//?here?since?Insert()?is?externally?synchronized.
??//?prev記錄的是查詢路徑,下面需要使用prev來修改新生成結(jié)點的指針??
??//?prev相當(dāng)于LevelDb源碼分析之五:skiplist(1)中的update
??//?整個流程與LevelDb源碼分析之五:skiplist(1)相似,這里不再詳細(xì)解釋
??Node*?prev[kMaxHeight];
??//?返回大于等于key的結(jié)點或者NULL,原因詳見FindGreaterOrEqual的分析
??Node*?x?=?FindGreaterOrEqual(key,?prev);

??//?Our?data?structure?does?not?allow?duplicate?insertion
??//?不允許插入重復(fù)的值??
??assert(x?==?NULL?||?!Equal(key,?x->key));
??//?產(chǎn)生一個隨機層數(shù)height
??int?height?=?RandomHeight();
??//?如果height大于原最大層數(shù),則更新prev,并更新最大層數(shù)
??if?(height?>?GetMaxHeight())?{
????for?(int?i?=?GetMaxHeight();?i?<?height;?i++)?{
??????prev[i]?=?head_;
????}
????//fprintf(stderr,?"Change?height?from?%d?to?%dn",?max_height_,?height);

????//?It?is?ok?to?mutate?max_height_?without?any?synchronization
????//?with?concurrent?readers.??A?concurrent?reader?that?observes
????//?the?new?value?of?max_height_?will?see?either?the?old?value?of
????//?new?level?pointers?from?head_?(NULL),?or?a?new?value?set?in
????//?the?loop?below.??In?the?former?case?the?reader?will
????//?immediately?drop?to?the?next?level?since?NULL?sorts?after?all
????//?keys.??In?the?latter?case?the?reader?will?use?the?new?node.
????max_height_.NoBarrier_Store(reinterpret_cast(height));
??}
??//?創(chuàng)建一個待插入的結(jié)點x,從低到高一層層插入
??x?=?NewNode(key,?height);
??//?逐層更新結(jié)點的指針,和普通鏈表插入一樣?
??for?(int?i?=?0;?i?<?height;?i++)?{
????//?NoBarrier_SetNext()?suffices?since?we?will?add?a?barrier?when
????//?we?publish?a?pointer?to?"x"?in?prev[i].
????x->NoBarrier_SetNext(i,?prev[i]->NoBarrier_Next(i));
????prev[i]->SetNext(i,?x);
??}
}

插入函數(shù)里調(diào)用了私有函數(shù)FindGreaterOrEqual。FindGreaterOrEqual中完成查詢操作,就是向下(level控制)和向右(x控制)移動過程,并不斷將經(jīng)過路徑保存到參數(shù)prev中。



templatetypename?SkipList::Node*?SkipList::FindGreaterOrEqual(const?Key&?key,?Node**?prev)
????const?{
??Node*?x?=?head_;
??int?level?=?GetMaxHeight()?-?1;
??//?從最高層往下,每層都查找插入位置,當(dāng)遍歷到該層的尾部(x->next[level]==NULL)??
??//?也沒有找到比key大的結(jié)點時,將該層的最后一個結(jié)點的指針放到prev[level]中。??
??//?如果在某層中找到了比key大或等于key的結(jié)點時,將該結(jié)點之前的那個比key小的結(jié)點的指針??
??//?放到prev[level]中。??
??while?(true)?{
????Node*?next?=?x->Next(level);
????if?(KeyIsAfterNode(key,?next))?{
??????//?Keep?searching?in?this?list
??????x?=?next;
????}?else?{
??????if?(prev?!=?NULL)?prev[level]?=?x;
	??//?當(dāng)查到第一層時,有兩種情況:
	??//?1.第一層中有滿足要求的結(jié)點,此時next剛好是不小于key的那個結(jié)點
	??//?2.第一層中沒有滿足要求的結(jié)點,此時實際上到了尾部,next=NULL
??????if?(level?==?0)?{
????????return?next;
??????}?else?{
????????//?Switch?to?next?list
????????level--;
??????}
????}
??}
}

三.查找函數(shù)


查找操作基本上就是調(diào)用函數(shù)上面的函數(shù)FindGreaterOrEqual實現(xiàn)。


templatebool?SkipList::Contains(const?Key&?key)?const?{
??Node*?x?=?FindGreaterOrEqual(key,?NULL);
??if?(x?!=?NULL?&&?Equal(key,?x->key))?{
????return?true;
??}?else?{
????return?false;
??}
}

需要注意的是,LevelDB中沒有提供顯式的刪除節(jié)點操作,但實際上是可以刪除的,因為當(dāng)我們插入數(shù)據(jù)時,key的形式為key:value,當(dāng)刪除數(shù)據(jù)時,則插入key:deleted類似刪除的標(biāo)記,等到Compaction再刪除。


本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護(hù)是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉