草庐IT

capacity

全部标签

java - 如何知道/获取hashmap的容量?

这个问题在这里已经有了答案:LoadfactorandCapacityofhashmap(2个答案)关闭8年前。我很好奇,我在documentation中看到了:Thecapacityisthenumberofbucketsinthehashtable...Theloadfactorisameasureofhowfullthehashtableisallowedtogetbeforeitscapacityisautomaticallyincreased.Whenthenumberofentriesinthehashtableexceedstheproductoftheloadfacto

c++ - C++ 中 std::vector 的基本问题

C++教科书和线程,例如these说vector元素在内存中是物理上连续的。但是当我们执行像v.push_back(3.14)这样的操作时,我会假设STL正在使用new运算符来获取更多内存来存储新元素3.14引入到载体中。现在假设大小为4的vector存储在标记为0x7,0x8,0x9,0xA的计算机存储单元中。如果单元格0xB包含一些其他不相关的数据,3.14将如何进入该单元格?这是否意味着单元格0xB将被复制到其他地方,并被删除以为3.14腾出空间? 最佳答案 简短的回答是将保存vector数据的整个数组移动到它有空间增长的位置

c++ - vector::resize 增加多少容量?

据我所知,当vector::resize需要增加时,C++标准并未明确指定如何增加vector容量。但是有没有“典型”的实现呢?具体来说:我不知道我的vector需要多大。此外,元素以随机顺序出现。所以对于每个元素我都有这个:if(index>=vector.size()){vector.resize(index+1);}vector.at(index)=element;如果元素以递增的索引顺序出现,vector容量是否会在每次调用调整大小时增加一(在典型的实现中)?我希望不会... 最佳答案 该标准不保证重复调用resize()的

c++ - 如何正确调整 vector 大小?

来自thisanswer:Oneplacewhereyoucanrunintoaperformanceissue,isnotsizingthevectorcorrectlytobeginwith.那么,当vector是一个类的属性时,如何正确调整其大小呢?是否有(最佳)方法来设置vector的容量(在初始化时)? 最佳答案 是的。查看reserve方法。它将要求vector的容量至少足以包含作为其参数发送的元素数。如果您可以预期要存储在vector中的项目数的上限,那么您可以在vector中保留该数量的空间。上面链接的例子-//ve

c++ - 未实现赋值运算符时调用构造函数

我正在VisualStudio2015中练习“字符串”类实现(C++)。我的类(class)有3个构造函数,但没有任何赋值运算符。String();String(char_c);String(constchar*_pc);在main()中,我故意使用赋值运算符来检查代码的行为。令我惊讶的是,它没有给出任何错误并使用构造函数String(constchar*_pc)为对象赋值。此外,在作用域的末尾,它调用了两次析构函数。在这种情况下,编译器在幕后做什么?为什么?这是我的代码:classString{private:intcapacity;char*start;public://Const

c++ - string::capacity/reserve() 算作终止 null 吗?

从cppref对capacity()的描述来看并不明显和reserve()是否计算终止空字符。 最佳答案 标准statesthat:Inallcases,size().和size()不包括终止空值。因为有可能size()等于capacity(),在这种情况下,这意味着capacity()也不计算终止空值。请注意,在C++11及更高版本中,mystring.c_str()相当于mystring.data()相当于&mystring[0],和mystring[mystring.size()]保证是'\0'.检查这个Demo.

c++ - C++ 字符串中 "size"和 "capacity"之间的区别?

我有ThinkinginC++中的这个片段。#include#includeintmain(){stringbigNews("IsawElvisinaUFO.");cout我得到如下所示的输出:IsawElvisinaUFO.thoughtIIsawElvisinaUFO.Size=33Capacity=44thoughtIIsawElvisinaUFO.I'vebeenworkingtoohard.Size=60Capacity=88我能弄清楚为什么大小会增加,但我无法弄清楚容量是如何增加的?我所知道的是Capacity是我们可以在其中进行Pushback的字符串缓冲区,但是该空间是

c++ - 有没有办法将双端队列的内部存储大小作为 vector::capacity?

我理解deque和vector都预留了一定的增长空间。vector::capacity()能够获取一个vector的内部保留空间。Deque在标准中没有这样的成员。有什么方法可以获取这些信息吗? 最佳答案 您必须深入研究实现才能弄清楚。gcc4.1.1附带的std::deque版本似乎以512字节block分配内存。但这就是我在盯着所有下划线和C风格转换为size_t15分钟后得到的。然后我看到了这条评论:Theinitialunderlyingmemorylayoutisabitcomplicated...

c++ - BGL 添加具有多个属性的边

我想让所有边都具有属性、重量和容量。我发现BGL已经定义了这些。所以我为图定义了Edge和Vertex属性typedefpropertyVertexProperty;typedefproperty>EdgeProperty;typedefadjacency_listGraph;这是我尝试将边添加到图形的地方:172:EdgePropertyprop=(weight,capacity);173:add_edge(vertex1,vertex2,prop,g);如果我只有1个属性,我知道它会是prop=5;但是,有两个我对格式感到困惑。这是我收到的错误:graph.cc:Infunctio

c++ - std::vector 的容量会减少吗?

C++14finalworkingdraft对std::vector做出以下评论:Storagemanagementishandledautomatically,thoughhintscanbegiventoimproveefficiency.cppreference说:Thestorageofthevectorishandledautomatically,beingexpandedandcontractedasneeded.和WikipediaentryforDynamicarray说:C++'sstd::vectorandRust'sstd::vec::Vecareimplemen