草庐IT

std-ranges

全部标签

c++ - 为什么 std::stof、std::stod 和 std::stold 处理带有异常的错误?

为什么std::stof的理由是什么?,std::stod,和std::stold抛出异常?http://en.cppreference.com/w/cpp/string/basic_string/stof输入错误是一个常用的例子,说明当通过异常处理错误时不合适(通常用“异常情况”的古怪循环推理来表达,但仍然是一个很好的例子)。C++标准库中并没有以某种方式禁止其他错误处理机制。例如,另一个C++11新人,std::unordered_map::insert系列,表示使用std::pair中的第二个元素失败返回类型。std::unordered_map::insert内的故障功能似乎比

c++ - push_back() "new"一个对象在添加到 c++ 中的 std::list 之前

我是C++标准库的新手。我想使用std::list。我知道如果我自己创建一个列表而不是使用STL,我应该为一个新对象分配内存,然后将它添加到列表中。A类的C风格列表:A*ptrA=newA();ptrA->setElement(value);ptrA->next=null;currentPositionMyCstyleList->next=ptrA;ptrA->prev=currentPositionMyCstyleList;如果我使用STL,是否有必要“新建”一个对象?push_back()在添加到c++中的std::list之前是否“新建”了一个对象?下面的代码是否正确?AaObj

c++ - 打印 std::this_thread::get_id() 给出 "thread::id of a non-executing thread"?

这曾经工作得很好(然后外星人一定黑了我的电脑):#include#includeintmain(){std::cout现在它打印thread::idofanon-executingthread。ideone.com打印了一些ID,但有趣的是是什么导致了我平台上的这种行为。$uname-aLinuxxxx3.13.0-77-generic#121-UbuntuSMPWedJan2010:50:42UTC2016x86_64x86_64x86_64GNU/Linux有什么想法吗?编辑:嗯..当我添加std::cout两行打印相同的ID,但是当我删除它时,结果仍然相同-“非执行线程”。

c++ - 为什么 std::setbase(2) 不切换到二进制输出?

Thecppreferencepageonstd::setbase说:Valuesofbaseotherthan8,10,or16resetbasefieldtozero,whichcorrespondstodecimaloutputandprefix-dependentinput.怎么会?仅支持这些碱基是否有特殊原因?支持至少16个(实际上,最多36个:0-9,然后是a-z)而不必做出任何困难的选择似乎是微不足道的。具体来说,2是一个流行的基础,我认为应该对std::setbase(2)(以及相应的std::binary)感兴趣。我显然可以打印我自己的位,但如果我的ostream能做

c++ - 从 std::true_type 继承 vs static constexpr const bool 成员

我知道这不是一个非常尖锐的问题。使用一个比另一个有优势(编译时间、依赖性、调试符号大小、可用性、可读性等)吗?templatestructIsSharedPtr:std::false_type{};对比templatestructIsSharedPtr{staticconstexprboolvalue=false;};相关问题...templatestructS;templatestructS{};templatestructS{};对比templatestructS;templatestructS{};templatestructS{}; 最佳答案

c++ - 在 std::function 中返回初始值设定项列表而不是 vector

Edit:Itisnotduplicatedofthelinkedquestion(whichisminealso).Hereallthereturntypesarestd::vector.Idonotwanttoreturnaninitializer-list.Iwanttofillthereturnedstd::vectorbyinitializer-listdirectly让我们以这四种情况为例:1)//Acceptablestd::vectorfoo(){returnstd::vector{1};}2)//Acceptablestd::vectorfoo(){return{1}

c++ - 使用模板作为 std::map 中的键

我想知道是否可以使用模板作为map的键。例如:std::map,Node>nodes;本质上,我想要做的是能够拥有一堆包含任意类型数据的节点,并以该数据为键。我想我可以通过将所述数据转换为二进制并以此为键来实现,但这很麻烦,我想避免它。澄清一下,我希望能够使用任何类型的变量作为键。例如,如果我有2个节点,一个包含一个int作为其数据,另一个包含一个Foo作为其数据,我希望能够使用它们的数据作为键将它们放在同一个映射中。也许map不是我想要的,我不确定...想法?谢谢! 最佳答案 如果您没有明确禁用RTTI,请参阅nogard的回答。

c++ - 为什么 std::thread 通过转发引用接受仿函数

为什么std::thread对象通过转发引用接受函数参数,然后使用decay_copy复制对象?只按值接受函数对象不是更容易吗?一般来说,为什么不对函数进行模板化以便按值获取函数对象?引用性不能用reference_wrapper来模仿吗(这会更明确,并且还方便地有一个成员operator()来调用存储的函数)? 最佳答案 Whydoesastd::threadobjectacceptthefunctionparameterbyforwardingreferenceandthenmakeacopyoftheobjectwithdec

c++ - 防止 gcc 中的 std::function 分配内存或增加阈值

有什么方法可以防止gcc中的std::function为较大的函数对象动态分配内存?我希望下面的代码可以在没有动态分配的情况下工作:#include#include//replaceoperatornewanddeletetologallocationsvoid*operatornew(std::size_tn){std::cout&stuff){returnstuff();}};intmain(){TestPlatetestor;testor.setValue(15);conststd::function&func=std::bind(&TestPlate::getValue,&te

c++ - 与 std::condition_variable 相比,使用 std::atomic 的方法 wrt 在 C++ 中暂停和恢复 std::thread

这是一个单独的问题,但与我之前提出的问题有关here我正在使用std::thread在我的C++不断轮询某些数据并将其添加到缓冲区的代码。我用C++lambda像这样启动线程:StartMyThread(){thread_running=true;the_thread=std::thread{[this]{while(thread_running){GetData();}}};}thread_running是一个atomic在类头中声明。这是我的GetData功能:GetData(){//Someheavylogic}接下来我还有一个StopMyThread我设置的功能thread_r