草庐IT

-std=gnu99

全部标签

c++ - 为什么 std::queue 使用 std::dequeue 作为底层默认容器?

如阅读cplusplus.com,std::queue实现如下:queuesareimplementedascontainersadaptors,whichareclassesthatuseanencapsulatedobjectofaspecificcontainerclassasitsunderlyingcontainer,providingaspecificsetofmemberfunctionstoaccessitselements.Elementsarepushedintothe"back"ofthespecificcontainerandpoppedfromits"fron

c++ - 为什么 std::atomic 的 compare_exchange 会引用期望值?

std::atomic::compare_exchange_*的原因是什么?通过引用获取期望值,而不是通过值获取期望值? 最佳答案 如果操作失败,compare_exchange_*会将expected更改为实际值。它使循环更简单一些。 关于c++-为什么std::atomic的compare_exchange会引用期望值?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1998

c++ - Qt Concurrent 或 std::async 用于新代码?

我正在考虑运行异步代码的两个选项:QtConcurrent和std::async.鉴于我正在使用Qt编写GUI应用程序,因此使用QtConcurrent是有意义的。然而std::async看起来也不错,并且得到了所有主要编译器的支持。我应该为新代码使用QtConcurrent还是std::async?比较两者时我还应该寻找什么? 最佳答案 GiventhatI'mwritingaGUIappwithQt,itmakessensetogowithQtConcurrent我想说,事情没那么简单。我个人会尽可能多地使用标准库。但是,需要考

c++ - STD 馆藏中引用文献的生命周期

对STD集合返回的元素(例如map)的引用有效多长时间?例如,在这段代码中:structEmployee{intsalary;stringname;//thekey};mapallemployees;...Employee&Joe=allemployees["JoeSmith"];Joe.salary=150;//change"JoeSmith"'ssalaryassert(allemployees["JoeSmith"].salary==150);//alwaystrue....allemployees["MarkJones"]=Employee();...//No"JoeSmith

c++ - 如何获取 std::unordered_map 的最后一个元素?

如何获取std::unordered_map的最后一个元素?myMap.rbegin()和--myMap.end()是不可能的。 最佳答案 容器中没有无序的“最后一个元素”。您可能需要一个有序的容器,例如std::map并使用mymap.rbegin()->first访问最后一个元素(另见thispost)编辑:要检查您的迭代器是否会到达末尾,只需递增它(并可能将其保存在临时文件中)并根据mymap.end()检查它,或者,甚至更干净:if(std::next(it)==last) 关于

c++ - 如何根据 `std::vector` 中的元素对 `std::set` 进行切片

有没有一种根据std::set中的元素对std::vector进行切片的好方法?换句话说,std::set中的元素包含我想要在vector中的索引。当然,我可以用代码完成这个:#include#include#include#includetemplatestd::vectorslice(std::vectorconst&x,std::setconst&I){autoy=std::vector();for(autoconst&i:I)y.push_back(x[i]);returny;}intmain(){autox=std::vector{1.2,2.3,3.4,4.5,5.6};a

c++ - C++17 std::shared_mutex 还不可用吗?

查看C++compilersupport,看来std::shared_mutex的未计时版本在GCC5.0+中可用。但是,即使使用gccversion5.3.020151204(Ubuntu5.3.0-3ubuntu1~14.04),并用-std=c++1z编译,共享互斥体的简单初始化以:error:‘shared_mutex’innamespace‘std’doesnotnameatypestd::shared_mutexmutex_;不,我已经包含了正确的header:#include.它找不到正确的header,因为它似乎不存在。实际上,链接器使用位于/usr/include/c

c++ - std::optional 和多态性

我在许多关于StackOverflow的帖子中读到,当使用指针(用于参数或返回值)并且允许使用nullptr(使其成为可选)时,通常最好使用std::optional代替。但是如果指针指向多态类型呢?最好使用std::optional还是指针? 最佳答案 optional不适用于多态类型。它是一种值类型,多态基类在optional中不起作用。就像将多态基类放在vector或类似的容器中是行不通的。返回一个指针。通常将建议表述为“一般”是有原因的。 关于c++-std::optional和

c++ - 如何将 std::bind 对象传递给函数

我需要将一个绑定(bind)函数传递给另一个函数,但我收到错误提示没有可用的转换-cannotconvertargument2from'std::_Bind&>'to'std::function&'函数:std::stringkeyFormatter(std::stringsKeyFormat,std::stringskey){boost::replace_all(sKeyFormat,"$ID$",skey);returnsKeyFormat;}用法就像-autofun=std::bind(&keyFormatter,sKeyFormat,std::placeholders::_2)

c++ - 使用 std::copy 的问题

我在使用标准复制功能时收到警告。我声明了一个byte数组。byte*tstArray=newbyte[length];然后我有几个其他字节数组,它们使用一些十六进制值声明和初始化,我想根据一些初始用户输入使用这些值。我有一系列if语句,我使用这些语句基本上解析出原始输入,并基于一些字符串,我选择要使用的字节数组,并在这样做时将结果复制到原始tstArray。例如:if(substr1=="15"){std::cout我得到的警告是警告C4996:“std::copy”:带参数的函数调用那可能不安全-此调用依赖于调用者检查传递的值是正确的。我认为,一个可能的解决方案是使用-D_SCL_S