草庐IT

MIN_CONTAINER_SIZE

全部标签

c++ - "const T& operator[](size_type i)"中的 const 有什么用?

我在一本书http://www.acceleratedcpp.com/中发现了这个有趣的行-资源-第11章-Vec.h(我是一个std::vector翻版)而且我真的不明白这个版本的运算符有什么用。为什么要定义此运算符的两个版本(常量和非常量)?我什至试过了,在我看来,非常量版本一直被调用......你能解释一下吗?#include#include#include#includeusingnamespacestd;templateclassVec{public:typedefT*iterator;typedefconstT*const_iterator;typedefsize_tsiz

C++:从 container1 中查找不在 container2 中的任何元素

我有一个std::set(s)和一个std::vector(五).保证vector是排序的/唯一的。我想知道v的所有元素是否都在s中(或者只是停在v的第一个元素而不是s中)。我可以将v转换成一个集合并进行==测试,但是有没有不改变容器类型的另一种方法? 最佳答案 关于std::includes的内容算法?这是一个简短的用法示例:vectorv1{1,2,4,8};vectorv2{1,2,3,8};sets{0,1,2,4,8,16};cout输出:10 关于C++:从container

C++ 自动类型转换 : wrong behaviour for a container class

我正在为非常小的常量vector和矩阵上的线性代数运算实现一些类。目前,当我这样做时:MyMathVectora={1,2,3};MyMathVectorb={1.3,2.3,3.3};std::cout然后First={2,4,6}和Second={2.3,4.3,6.3},因为第二个元素被编译器转换为第一个元素类型。是否有任何“简单”的方法来提供与nativeC++中相同类型的自动转换:int+double=double,double+int=double?非常感谢。编辑:使用答案给出的语法,我让operator+工作了。但我尝试了以下语法,编译失败并出现错误:expectedat

c++ - 使用 -1 作为无符号 (size_t) 类型的标志值

我使用-1作为返回类型为size_t(无符号类型)的函数的标志值。一开始我没有注意到它,特别是因为它没有在我的代码中造成任何错误(我用x==-1来检查它,而不是x有什么微妙的原因我不应该保持原样吗?这什么时候可能会出乎意料?这个常用吗?ptrdiff_t不太常见,需要更长的输入时间,而且它并不是真正合适的类型,因为该函数返回数组的索引。 最佳答案 -1将始终转换为最大无符号值,这是由于4.7Integralconversions部分:Ifthedestinationtypeisunsigned,theresultingvalueis

c++ - 使用 mingw-w64 工具链时,以 Release模式链接的 Regex Boost 库会发出 "duplicate section has different size"警告

在Release模式下链接我的项目时,我收到以下警告:myProject-libs/release/libboost_regex-mt-s-1.50.0.a(cpp_regex_traits.o):duplicatesection`.data$_ZZN5boost16cpp_regex_traitsIcE21get_catalog_name_instEvE6s_name[boost::cpp_regex_traits::get_catalog_name_inst()::s_name]'hasdifferentsize我怀疑原因可能是boost库的编译选项与我在项目中使用的选项不同,但我

c++ - GOOGLE_PROTOBUF_MIN_PROTOC_VERSION 检查期间编译时出现 Protocol Buffer 错误

我目前收到一个错误,它指向protoc生成的头文件中的这些行:#if2006001但我的协议(protocol)版本与上面的版本匹配:protoc--versionlibprotoc2.6.1我做错了什么?最初我的protoc版本是3.0.0然后通过同步回2.6.1并执行这些步骤重新安装它;makedistclean,./configure,make,makeinstall安装所需的2.6.1版本。我需要旧版本,因为那是我们服务器中安装的版本。 最佳答案 问题是您系统上安装的header(在/usr/include/google/p

c++ - 施放 ssize_t 或 size_t

在我的项目中使用的源文件中,ssize_t和size_t变量之间有一个比较:ssize_tsst;size_tst;if(sst==st){...}我想摆脱警告:warning:comparisonbetweensignedandunsignedintegerexpressions但我不确定,我应该将哪个变量转换为另一个变量?if((size_t)sst==st){...}或if(sst==(ssize_t)st){...}什么更安全、更好、更清洁?谢谢 最佳答案 这个问题没有唯一的正确答案。有几种可能的答案,具体取决于您对这些变量

c++ - UINT_MIN 的可移植值是多少?

在limits.h中,有INT_MAX和INT_MIN(以及SHRT_*和LONG_*等)的#defines,但是只有UINT_MAX。我应该自己定义UINT_MIN吗?0(正零)是可移植值吗? 最佳答案 它是一个无符号整数-根据定义,它的最小可能值为0。如果你想要一些除了常识之外的理由,standard说:6.2.6.2IntegertypesForunsignedintegertypesotherthanunsignedchar,thebitsoftheobjectrepresentationshallbedividedinto

c++ - 标准 : container c++ move to front

我正在寻找一个像std::list这样可以有效地将元素移到前面的std容器:a-b-c-d-e将“b”移到前面:a-c-d-e-b标准容器中没有这样的功能。因此,我认为我必须结合remove和push_front函数,但有没有人能找到更好的主意?提前致谢。 最佳答案 如果你不必维护其他元素的顺序,那么最简单的解决方案无疑就是交换您想要的元素与容器中的第一个元素。这个将对所有容器有效。否则,std::list提供了一个splice操作,它可以使用。我认为类似于以下内容:voidmoveToFront(std::list&list,st

c++ - constexpr 上下文中 std::array 指针的 size()

假设我有一个函数:inttest(std::array*data){charbuffer[data->size()*2];[...somecode...]}显然可以在编译时评估缓冲区的大小:数据的constexpr大小为8个元素,8*2=16字节。然而,当使用-Wall、-pedantic和-std=c++11编译时,我得到了臭名昭著的错误:warning:variablelengtharraysareaC99feature[-Wvla-extension]我认为这是有道理的:array::size()是constexpr,但它仍然是一个方法,在上面的函数中我们仍然需要取消引用一个指针