草庐IT

c++ - 通过隐式转换为字符串流式传输对象时重载解析失败

免责声明:我知道应该避免隐式转换为字符串,正确的方法是opPerson过载.考虑以下代码:#include#include#includestructNameType{operatorstd::string(){return"wobble";}};structPerson{NameTypename;};intmain(){std::cout它yieldsthefollowingonGCC4.3.4:prog.cpp:Infunction‘intmain()’:prog.cpp:18:error:nomatchfor‘operator&std::basic_ostream::operat

c++ - 为什么可以将 std::bind 分配给参数不匹配的 std::function?

我有如下代码:#include#includeusingnamespacestd;voidF(intx){coutf1=std::bind(F,std::placeholders::_1);f1(100);//Thisworks,willprint100.intx=0;std::functionf2=std::bind(F,x);f2();//Thisworks,willprint0.std::functionf3=std::bind(F,x);f3(200);//BUTWHYTHISWORKS??????Itprints0.return0;}我的编译器信息是:AppleLLVM版本6

c++ - 使用 std::hexfloat 读写

这段代码在我的机器上打印了0,但我期望是0.3。怎么了?我在最新的ArchLinux上使用g++6.3.1。编译标志似乎无关紧要。#include#includeintmain(){std::stringstreams;s>std::hexfloat>>d)std::cout 最佳答案 使用doubled=std::strtod(s.str().c_str(),NULL);作为解决方法。这似乎是一个错误。 关于c++-使用std::hexfloat读写,我们在StackOverflow上

c++ - 错误 C2893 : Failed to specialize function template 'unknown-type std::invoke(_Callable &&,_Types &&...) noexcept(<expr>)'

下面是一个给出编译时错误的程序。这主要与D类中的Boo函数有关。我最终尝试使用多个线程来调用solve方法,但目前这对我来说似乎不太有效,无法做到这一点。错误是:1>d:\dummy\project1\trash.cpp(37):warningC4101:'d':unreferencedlocalvariable1>c:\programfiles(x86)\microsoftvisualstudio\2017\community1\vc\tools\msvc\14.11.25503\include\thr\xthread(240):errorC2672:'std::invoke':no

c++ - 如何使用STL获取系统的小数分隔符?

要使用正确的数字分隔符('.'或',')生成csv文件,因为我希望它们与机器上安装的Excel版本兼容,我需要从C++程序中获取小数点分隔符。我的机器有法语版的Windows/Excel,所以小数点分隔符是','。intmain(){std::cout>(std::cout.getloc()).decimal_point();return0;}输出.,这不是预期的我尝试使用WIN32API:intmain(){TCHARszSep[8];GetLocaleInfo(LOCALE_USER_DEFAULT,LOCALE_SDECIMAL,szSep,8);std::cout输出,,这是预

c++ - 创建索引有序映射

过去几天,我浏览了这里和类似的网站,花了很多时间试图找到解决方案,并想寻求建议。我得出了一个令人失望的结论,即如果不进入C++的boost库,就不可能创建一个保留索引顺序的关联容器。更清楚和具体的是,我需要的是一个map,它可以使用operator[key]进行查找,但也可以在为迭代目的添加元素的顺序中建立索引。今天早上我决定我需要自己写一个,我已经尝试了一些使用map的map和成对的vector等的方法。但实际上没有任何效果,并且令人惊讶地获得了我正在寻找的所有功能用这种语言不容易实现。我一定是错的吧?有没有其他人有过需要此功能或熟悉此概念的经验,可以为我指明我正在寻找的正确方向?非

c++ - 协程 TS 2017 的实现示例

在C++coroutinesTS(2017),有一个等待对象的例子。templateautooperatorco_await(std::chrono::durationd){structawaiter{std::chrono::system_clock::durationduration;...awaiter(std::chrono::system_clock::durationd):duration(d){}boolawait_ready()const{returnduration.count()h){...}};returnawaiter{d};}usingnamespacestd

c++ - std::remove_if 和 erase 不从 std::vector 中移除元素

我正在练习leetcodeeasy问题。我想使用lambda从vector中删除_if(这是第一次,太棒了)。我得到一个指向new_end的负指针。#include#include#include#include//std::greaterusingnamespacestd;intmain(){vectora={2,7,11,15};inttarget=9;autonew_end=std::remove_if(a.begin(),a.end(),[&a,target](constintx){returnstd::count(a.begin(),a.end(),x)>target;});

c++ - 在构造函数中初始化成员时,是否应该在成员上使用 std::move?

我一直在努力完全理解移动语义,但我有一个问题,因为不同的示例显示不同的东西。假设我们有一个Foo类,它有一个字符串成员str_。要定义移动构造函数,我应该这样定义它吗:Foo(Foo&&foo):str_(foo.str_){}或者这个:Foo(Foo&&foo):str_(std::move(foo.str_)){}此外,我是否需要将要移动的对象的成员设置为空值?如果不构造另一个字符串,我将如何做到这一点,从根本上抵消了首先使用移动构造函数节省的费用? 最佳答案 你应该使用第二种方法。您不必对您移动的string做任何事情,因为这

c++ - 如何从移动捕获 lambda 表达式创建 std::function?

我正在尝试创建一个std::function来自移动捕获lambda表达式。请注意,我可以毫无问题地创建移动捕获lambda表达式;仅当我尝试将其包装在std::function中时我得到一个错误。例如:autopi=std::make_unique(0);//noproblemshere!autofoo=[q=std::move(pi)]{*q=5;std::coutbar=foo;std::functionbar{foo};std::functionbar{std::move(foo)};std::functionbar=std::move(foo);std::functionba