草庐IT

C++ std::set::erase 与 std::remove_if

此代码有VisualStudioerrorC3892。如果我将std::set更改为std::vector-它有效。std::seta;a.erase(std::remove_if(a.begin(),a.end(),[](intitem){returnitem==10;}),a.end());怎么了?为什么我不能将std::remove_if与std::set一起使用? 最佳答案 您不能使用std::remove_if()具有const的序列部分。std::set的序列元素由Tconst组成对象。事实上,我们昨天在标准C++委员会

c++ - 我可以在从另一个线程插入/删除时访问 C++11 std::map 条目吗?

我可以在另一个线程插入/删除条目时访问(不锁定)std::map条目吗?示例伪C++:typedefstruct{intvalue;intstuff;}some_type_t;std::mapmy_map;//thread1does:my_map.at('a')->value=1;//thread2does:some_type_t*stuff=my_map.at('b');//thread3does:my_map.erase('c');//I'mnotmodifyinganyelementsTisapointertoanpreviouslyallocated"some_type_t"s

c++ - 检测迭代器是否是 std::map 的最后一个元素

这类似于thisquestion但不是重复的。我正在尝试遍历map并打印每个元素的值,但最后一个元素的输出略有不同。在那个问题中,他们建议使用map.rbegin().base(),但它对我不起作用。这是我的代码:#include#includeintmain(){std::mapcharMap={{'a',1},{'b',2},{'c',3},{'d',4}};for(autoiter=charMap.begin();iter!=charMap.end();iter++){std::coutfirstsecond;if(iter==charMap.rbegin().base())st

c++ - 如何为 C++ 元组编写折叠/求和函数?

我想为std::tuple编写一个fold函数,它可以计算例如给定元组中所有元素的总和(或乘积)。例如,给定std::tuplet=std::make_tuple(1,2);我想计算autos=sumT(t);//giving3我试过但无法编译下面的模板编程(c++11/1z)代码。我还尝试为我的其他问题(HowtoperformtuplearithmeticinC++(c++11/c++17)?)调整已接受的答案,但无法弄清楚如何在这种情况下使用std::index_sequence。我遇到的问题是:1)我无法弄清楚类型,例如如何使用第一个元素的类型作为返回类型。目前,我在模板中使用

c++ - 没有堆的 static const std::vector<char> 初始化?

假设我想要一个无符号字符的std::vector。它是用初始化列表(这是C++11)初始化的,永远不会改变。我想避免任何堆分配,即使在启动时也是如此,并让整个vector像const字符串一样存在于数据段中。那可能吗?IE:staticconstvectorv{0x1,0x2,0x3,0x0,0x5};(这是一个有点学术性的问题;我知道为此使用C数组并不难。) 最佳答案 为什么不直接使用std::array为此?staticconststd::arrayv{0x1,0x2,0x3,0x0,0x5};这避免了任何动态分配,因为std:

c++ - 在 std::conditional 中使用不完整类型的 sizeof

这是一个最小的例子:structincomplete_type;templatestructfoo{usingtype=std::conditional_t,std::conditional_t,double>;};foof;会导致错误,因为它会对类型执行sizeof,即使incomplete_type不是算术类型(iow,它不会在逻辑上进入sizeof分支)。livedemo所以,我想推迟sizeof:第一次尝试(失败)templateautofoo_aux(){if(sizeof(T)conditional_t,decltype(foo_aux()),double>仍然触发相同的错

c++ - std::lock_guard 有什么问题

我有简单的代码:第一个线程将std::strings推送到std::list,第二个线程弹出std::strings从这个std::list。所有std::list的操作都受到std::mutexm的保护。此代码将错误永久打印到控制台:"Error:lst.begin()==lst.end()"。如果我将std::lock_guard替换为构造m.lock()和m.unlock()代码将开始正常工作。std::lock_guard有什么问题?#include#include#include#include#includestd::mutexm;std::listlst;voidf2()

c++ - 使用 STL 函数快速填充 vector 、映射和设置

我想用一些数据快速填充这些容器以进行测试。最好和最快的方法是什么?它不应该太复杂,因此短得不人道,但也不要冗长编辑伙计们,我认为你可以用memset做一些事情,知道vector有一个下划线数组?另外,map呢? 最佳答案 boost赋值库方式(http://www.boost.org/doc/libs/1_38_0/libs/assign/doc/index.html)使用命名空间boost::assign;std::vectorv;v+=1,2,3,4,5,6,7,8,9;std::mapm;insert(m)("Bar",1)(

c++ - 我可以使用 std::vector 来调用接受数组/指针参数的函数吗?

我想重写一些使用大量unsignedchar的代码数组,而不是使用std::vector对象。我遇到的问题是,这些当前用于存储将写入串行端口或套接字写入缓冲区的数据,而执行此操作的库函数采用void*。或unsignedchar*.这种功能的一个例子是WriteToSocketBuffer(unsignedchar*pBuffer,intiSize);所以目前我有表单的代码unsignedchar*pArray=newunsignedchar[iSize];//populatearraywithdataWriteToSocketBuffer(pArray,iSize);delete[]

c++ - std::greater<double> 和 std::less<double> 使用安全吗?

比较double时C++中的值,使用,=,!=运算符,我们不能总是确定结果的正确性。这就是为什么我们使用其他技术来比较doubles,例如,我们可以通过测试它们的差异是否真的接近于零来比较两个doublea和b。我的问题是,C++标准库是否实现了std::less和std::greater使用这些技术,还是仅使用不安全的比较运算符? 最佳答案 您可以100%确定这些运算符结果的正确性。只是先前的计算可能导致截断,因为double不是无限的。所以运算符非常好,只是您的操作数不是您期望的那样。因此,您使用什么进行比较并不重要。