草庐IT

-std=gnu99

全部标签

c++ - std::vector 和 std::list 的重载运算符

我想重载operator对于std::list和std::vector使用以下代码。但是两者的功能几乎是一样的。有什么方法可以将它们组合起来,即,创建一个更通用的重载?#include#include#include#includetemplatestd::ostream&operator&v){if(!v.empty())std::copy(v.begin(),v.end(),std::ostream_iterator(out,","));returnout;}templatestd::ostream&operator&v){if(!v.empty())std::copy(v.beg

c++ - 如何使用 lambda 作为 std::unique_ptr 的删除器?

检查以下设计的程序:#include#includetemplateusingUniPtr=std::unique_ptr>;int*alloc(){returnnewint;}UniPtrfunc(){autodealloc=[](int*p){deletep;};returnUniPtr{alloc(),dealloc};}intmain(){autop=func();return0;}来自std::functionconstructormanual,我认为构建std::function对象可能会抛出异常,即使这个比例很低:UniPtrfunc(){autodealloc=[](i

c++ - lambda 如何在 MSVC2017 15.9.3 with/std :c++17? 中使用静态本地错误返回值

下面的示例代码打印来自lambda函数的值,该函数简单地递增并返回静态局部计数器变量的值。它打印0,1和2,3正如预期的那样,gcc和C++17的clang。但在VisualStudioCommunity201715.9.3中没有/std:c++17设置-它打印0,0和2,3相反。#includeintmain(){autof=[]{staticinti=0;returni++;};constintv1=f();//Expectv1=0constintv2=f();//Expectv2=1//Printsthewrongvalues(MSVC15.9.3with/std:c++17)s

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++ - 编写 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的值?,我们