草庐IT

MIN_CONTAINER_SIZE

全部标签

c++ - 是否有采用投影函数的 min_element 变体?

std::min_element将返回由operator定义的最小元素或通过自定义谓词boolPred(T,T).是否有类似的函数返回投影函数f(T)->R所针对的元素取最小值?显然我可以定义boolPred(t1,t2){returnf(t1)但当f是lambda时,这有点不方便。 最佳答案 为什么不使用来自Boost.Iteratorlibrary的boost::transform_iterator(以前称为projection_iterator_adaptor)autoPred=[](some_value_typeconst&

c++ - 为什么 std::min(std::initializer_list<T>) 按值获取参数?

阅读thisquestion的答案,我惊讶地发现std::min(std::initializer_list)按值获取其参数。如果您使用std::initializer_list以其名称所暗示的方式,即作为某个对象的初始值设定项,我知道我们不关心复制它的元素,因为它们无论如何都会被复制以初始化对象。然而,在这种情况下,我们很可能不需要任何拷贝,因此将参数视为std::initializer_list似乎更合理。如果可能的话。这种情况下的最佳做法是什么?你不应该调用initializer_list吗?std::min的版本如果您关心不要进行不必要的复制,或者是否有其他一些技巧可以避免复制

c++ - 是否有标准名称(模板或宏)来替换 ARRAY_SIZE、_countof 等?

我不是在谈论std::array或任何东西,只是经典的VanillaC/C++数组。我知道可以实现ARRAY_SIZE/_countof的各种方式,我只是想知道他们是否已经设法为此标准化了一个名称(在std::我假设)。如果没有,是否有相关建议? 最佳答案 当前的解决方法std::extent-数组的大小如果您正在使用native数组,您可以使用std::extent来自,用于生成数组的Nth维(默认为第一个)中的元素数。inta1[1024];inta2[std::extent::value];//int[1024]一点间接(通用

c++ - 为什么小于运算符接受不同类型的参数而 std::min 不接受?

#includeintmain(){inta=1;longlongb=2;std::cout>Infileincludedfrom/usr/include/c++/4.8/bits/char_traits.h:39:0,>from/usr/include/c++/4.8/ios:40,>from/usr/include/c++/4.8/ostream:38,>from/usr/include/c++/4.8/iostream:39,>fromsum_to.cpp:1:/usr/include/c++/4.8/bits/stl_algobase.h:239:5:note:template

C++11 auto 和 size_type

鉴于auto的以下用法:std::vectorv;for(autoi=0;i对于C++来说,推导i将是理想的选择作为std::vector::size_type,但如果它只查看i的初始化程序,它会看到一个整数。i的推导类型是什么?在这种情况下?这是auto的适当用法吗?? 最佳答案 使用decltype而不是auto来声明i。for(decltype(v.size())i=0;i更好的是,如@MarkB的回答所示,使用迭代器迭代vector。 关于C++11auto和size_type,

c++ - 将 size() 用于 for 构造中的第二个表达式总是不好的吗?

在下面的示例中,我是否应该期望每次循环时都会调用values.size()?在这种情况下,引入一个临时的vectorSize变量可能是有意义的。或者现代编译器是否应该能够通过识别vector大小不能改变来优化调用。doublesumVector(conststd::vector&values){doublesum=0.0;for(size_tii=0;ii请注意,我不关心是否有更有效的方法来对vector的内容求和,这个问题只是关于在for结构中使用size()。 最佳答案 这是一种明确的方法-size()只被调用一次。for(si

c++ - "container"和 "data structure"有什么区别?

什么是容器?据我了解:抽象数据类型只是对数据存储方式和允许对该数据进行的操作的逻辑描述。例如,堆栈被定义为具有压入、弹出等操作和后进先出访问的数据类型。一个数据结构就是这个抽象定义的实际实现,在一些计算机编程语言中,例如C++中的栈,在标准库中的实现是std::stack。首先,请纠正/加强我目前对上述区别的理解。其次,容器到底是什么?我经常听到这个词。和我定义的数据结构一样吗?此外,维基百科为这些术语提供了三个单独的条目。 最佳答案 没什么,真的。正如我们人类喜欢做的那样,它们只是同一个词的两个词。然而,afaik,官方CS术语是

c++ - 我可以始终使用 std::inserter(container, container.end()) 而不是 std::back_inserter(container) 吗?

std::back_inserter仅适用于带有push_back的容器,因此它不适用于set和map另一方面,std::inserter适用于所有容器类型。那么我可以一直使用std::inserter(container,container.end())吗?那么下面的代码是否适用于所有类型的容器?templateTContainercreate(TElementelement){TContainercontainer;autoinserter=std::inserter(container,container.end());for(inti=0;i>(1);create>(1);

c++ - size_t 参数新运算符

我有一点想不通新运算符重载。假设,我有一个类MyClass但MyClass.hMyClass.cpp和main.cpp文件是这样的;//MyClass.hclassMyClass{public://Somememberfunctionsvoid*operatornew(size_tsize);voidoperatordelete(void*ptr);//...};//MyClass.cppvoid*MyClass::operatornew(size_tsize){returnmalloc(size);}voidMyClass::operatordelete(void*ptr){free

c++ - std::string 实现是否符合 's.c_str() + s.size()' 不一定与 '&s[s.size()]' 相同?

§21.4.5[string.access]const_referenceoperator[](size_typepos)const;referenceoperator[](size_typepos);Returns:*(begin()+pos)ifpos.Otherwise,returnsareferencetoanobjectoftypecharTwithvaluecharT(),wheremodifyingtheobjectleadstoundefinedbehavior.至少对我来说,第二部分意味着这个“charT类型的对象”可能位于存储在std::string中的序列之外。目