草庐IT

c++ - std::min 正在重新定义,但如何定义?

streflop或boost库会更改std::min的定义吗?我有一个使用g++/make编译良好的项目,直到我将它与另一个项目的CMake构建合并(使用add_directory)。突然我得到:nomatchingfunctionforcalltomin(double&,float)它声称错误所在的行号是错误的(它指向源文件的最后一行)但我假设相关代码是这样的:first=std::min(first,key.mTime);其中first被声明为double。“父”项目(SpringRTS)使用boost和streflop,但即使在替换了所有包含之后也是如此与"streflop_co

c++ - 编写 c++ 函数 format_string 进行格式化,如 std::string 的 sprintf

为了方便使用,我想编写类似于sprintf的格式化函数,只返回std::string,如下所示:std::stringformat_string(constchar*format,...)我可以在那里使用vsnprintf但有问题-我事先不知道临时缓冲区应该有多长。Microsoft上有函数_vscprintf可以做到这一点,但我认为它不可移植?一个选项是让临时缓冲区开始一些已知的大小,然后如果发现它不够用vsnprintf增加它。有更好的方法吗?谢谢附言请在没有提升的情况下给出答案。我知道Boost,但我很好奇如何在没有Boost的情况下实现它。 最佳答案

c++ - Mac OS X 和静态 boost 库 -> std::string 失败

我在使用GCC4.5的MacOSX10.6.6下遇到静态boost库(来自MacPorts的Boost1.45.0-2,编译为fat/universal(x86/x86_64)库)的一些非常奇怪的问题。错误信息是main(78485)malloc:***errorforobject0x1000e0b20:pointerbeingfreedwasnotallocated***setabreakpointinmalloc_error_breaktodebug[1]78485abort(coredumped)还有一小段会触发这个问题的示例代码:#defineBOOST_FILESYSTEM_

c++ - 跨流行工具链的标准容器重新分配乘数

std::basic_string和std::vector等容器在内部容量用完时执行自动重新分配。该标准规定,在重新分配后,.capacity()>=.size()。主流工具链在执行重新分配时使用的一些实际乘数是什么?更新到目前为止,我有:Dinkumware:1.5(shipswithMSVSandpossiblyICC)GNUlibstdc++:2(shipswithGCCandpossiblyICC)RW/Apachestdcxx:1.618(akaφ)STLport:2 最佳答案 旧问题的新答案。基本原理:可以通过编程方式和

c++ - std::function<> 和 Intel 编译器版本 11.1

我在使用英特尔编译器中的lambda函数时遇到问题,特别是以下代码无法编译:templatestd::functionmake_func(Tx){return[=](intindex)->T{returnx;};}我得到的错误是error:namespace"std"hasnomember"function"代码在我的Mac上编译和运行良好(macportsgcc版本4.5)。错误在起作用,我们使用的是Intel编译器版本11.1。它确实接受lambda函数(使用-std=c++0x选项),例如:autolam=[=](intj)->int{printf("testingforlamb

c++ - 如何在成功或失败的情况下返回 std::copy 的值?

我正在使用std::copy将std::deque中的对象复制到一个文件中。代码运行良好,但我需要检查复制是否成功,因此我需要设置标志或抛出异常。我用谷歌搜索但找不到如何检查std::copy是否已成功将值复制到文件中的解决方案。有人可以给它点亮吗。 最佳答案 如果写入文件失败,则文件流的错误标志将被设置-您可以在复制后检查这些,或者先调用exceptions成员函数使其抛出异常错误。如果其他方法失败,则会抛出异常。 关于c++-如何在成功或失败的情况下返回std::copy的值?,我们

c++ - std::string 到 std::array?

将字符串转换为数组的推荐方法是什么?我正在寻找类似的东西:templatestd::arrayto_array(constV&v){assert(v.size()==N);std::arrayd;std::copy(v.begin(),v.end(),d.data());returnd;}C++11或Boost是否提供类似的东西?其他人如何做到这一点?每次我在项目中需要时都必须自己复制/粘贴这个函数,这似乎很愚蠢。 最佳答案 这看起来不错。C++11中没有这样的东西,我认为Boost中也没有。如果你不想把它到处粘贴,你可以把它放在一

c++ - 使用 std::map 的 Visual Studio 11 编译时错误

以下代码可以使用gcc-4.5.1编译,但不能在VisualStudio11中编译。#include#includetypedefstd::pair>pairus;intmain(){std::map>x;std::arraytroll={1,2,3,4};x.insert(pairus(1,troll));autoz=x[1];}1现在映射到std::arraytroll.插入效果很好,程序可以编译。但是,一旦我尝试autoz=x[1]->因此试图获得1的数组troll被映射到,程序不编译并出现以下错误:errorC2512:'std::array::array':没有合适的默认构造

c++ - std::is_convertible 用于 type_info

在C++11中,可以通过usingstd::is_convertible确定类型A的变量是否可以隐式转换为类型B.如果你真的知道类型A和B,这很有效,但我只有type_infos。所以我正在寻找的是这样的功能:boolmyIsConvertible(consttype_info&from,consttype_info&to);是否可以在C++中实现类似的东西?如果是,怎么办? 最佳答案 在可移植的C++中做你想做的事是不可能的。可能如果您将自己限制在给定的平台上,则有可能获得部分答案。例如那些遵守ItaniumABI的平台将实现此功

c++ - 使用 std::vector 重新分配的内存取消分配

假设我有VectorA和VectorB是两个std::vector,都已初始化(我的意思是VectorA.size()>0和VectorB.size()>0)如果我这样做:VectorA=VectorB;之前为VectorA分配的内存自动释放? 最佳答案 在调用所有包含对象的析构函数并且vector不再拥有内存的意义上,它被释放。1但实际上,它只是返回到allocator,实际上可能会也可能不会将其返回给操作系统。只要正在使用的分配器中没有错误,就不会造成内存泄漏,如果这是您所关心的。1。正如@David在下面的评论中指出的那样,内