草庐IT

STD_PROP_LIST

全部标签

c++ - 为什么我得到 std::exp 的平台特定结果?

这个问题在这里已经有了答案:Isfloatingpointmathbroken?(31个答案)MathprecisionrequirementsofCandC++standard(1个回答)关闭3年前。我有一个程序在Android和Windows下给出了截然不同的结果。当我根据包含预期结果的二进制文件验证输出数据时,即使差异很小(舍入问题)也很烦人,我必须找到一种方法来修复它。这是一个示例程序:#include#include#includeintmain(intargc,char*argv[]){//thisvaluewasidentifiedasproducingdifferent

c++ - 为什么这个不正确的 std::function 初始化使用 MSVC 编译?

今天遇到一个有趣的问题,由我自己的错字引起。我创建了一个lambda,它接收对结构的引用,并错误地将其设置为std::function,该函数按值接收它的参数。这是一个更简洁的版本:#includestructInputStruct{inti;InputStruct():i(1){}};voidfunction_rcv(std::function&func_ref){InputStructin;func_ref(in);}intmain(){std::functionmy_func=[](InputStruct&in)->bool{returnin.i==1;};function_rc

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++ - G++ 4.5 错误 : No diagnostic for narrowing in initializer list

我尝试了以下代码:intmain(){intx{23.22};}其中包括需要缩小的初始化,但代码编译正常,没有任何错误或警告。另一方面,以下代码给出了错误:intmain(){intx[]{23.22};}我是发现了错误还是什么?PS:我目前使用的是GCC4.5.0 最佳答案 看起来像一个错误。以下直接来自n3092草案:8.5.4List-initialization—Otherwise,iftheinitializerlisthasasingleelement,theobjectisinitializedfromthatelem

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::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':没有合适的默认构造