2007年5月9日星期三

STL Map 无Reserve和Resize的原因 / Why STP MAP can not provide function Reserve() and Resize()

今天翻论坛,看到一些帖子问为什么STL Map不提供Reserve函数和Resize函数. 这个问题从MAP的实现比较容易理解.
MAP的低层实现是红黑树,要求每个节点都有一个不重复的key值. 如果提供Reserve和Resize功能,那么就要预分配一部分节点, 那么这些节点的key值设置成什么呢? 全为0不满足节点key不能重复的要求,又不能随即设置,因为那样会导致map根据key值重新排列. 所以MAP不可能可以提供Reserve和Resize的功能.

When reading bbs today, I found some ppl asking why STL map does not provide function Reserve() and Resize(). Considering this question from the technique machenism of STL MAP, the reason could be clear.

The low level data structure of STL map is RB Tree, it requires every node of it must have a unique key. If Reserver() and Resize() is provided, then the tree need pre-allocate some nodes. But how to initialize the key of this new nodes? If they were all filled zero, then the keys are repeated; If the are other random or different keys, it will cause a much more bad result: the tree need reassign the position of the nodes according to the keys.

So map must not provide function Reserver() and Resize().

8 条评论:

匿名 说...

Hello! This is my first comment here so I just wanted to give
a quick shout out and tell you I truly enjoy reading your blog posts.
Can you recommend any other blogs/websites/forums that deal with the
same topics? Thanks a ton!
Also see my web page: lanautica

匿名 说...

We are a gaggle of volunteers and opening a new scheme in our community.
Your web site provided us with helpful info to work on.
You've performed a formidable process and our entire neighborhood will be thankful to you.
Visit my web blog : click the up coming article

匿名 说...

Hello! I just wanted to ask if you ever have any problems with hackers?
My last blog (wordpress) was hacked and I ended up losing several weeks of hard
work due to no backup. Do you have any solutions to prevent hackers?


Here is my website ... Green tea weight loss

匿名 说...

I am regular reader, how are you everybody? This post posted at this website is really
fastidious.

Also visit my blog ... website murah

匿名 说...

Hi there everybody, here every person is sharing
such experience, so it's fastidious to read this weblog, and I used to pay a visit this web site everyday.

My website bayou adjustable dumbbells

匿名 说...

What a stuff of un-ambiguity and preserveness of valuable knowledge regarding
unexpected emotions.

my web page ... Diablo 3
my web page: Diablo 3

匿名 说...

What's up, this weekend is pleasant in favor of me, as this occasion i am reading this enormous educational paragraph here at my home.

my weblog asianpussysex.com

匿名 说...

Does your site have a contact page? I'm having problems locating it but, I'd like to send you an
e-mail. I've got some suggestions for your blog you might be interested in hearing. Either way, great blog and I look forward to seeing it grow over time.

Here is my web page: amazing free xxx porn pussy video sex clips