草庐IT

c++ - 检查 C++11 中返回的 std::function 是否为 "valid"

我想像这样实现一个动态任务队列:typedefstd::functionJob;typedefstd::functionJobGenerator;//..JobGeneratorgen=...;autojob=gen();while(IsValidFunction(job)){job();}如何实现IsValidFunction?std::function是否有某种默认值可供检查? 最佳答案 您可以简单地检查job作为一个bool值:while(autojob=gen()){job();}这是一种简写形式,它赋值job来自gen()

c++ - 如何迭代 std::string 中的所有正则表达式匹配及其在 c++11 std::regex 中的起始位置?

我知道两种从std::string获取正则表达式匹配的方法,但我不知道如何获取所有匹配及其各自的偏移量。#include#include#includeintmain(){usingnamespacestd;strings="123apples456oranges789bananasorangesbananas";regexr=regex("[a-z]+");constsregex_token_iteratorend;//hereIknowhowtogetalloccurences//butdon'tknowhowtogetstartingoffsetofeachonefor(sreg

C++11 future.wait_for() 总是返回 future_status::timeout

我有一个C++11程序来检查一个数是否为素数。程序等待准备就绪的future对象。准备就绪后,程序会告知future对象的提供者函数是否认为该数字是质数。//futureexample#include//std::cout#include//std::async,std::future#include//std::chrono::millisecondsconstintnumber=4;//444444443//anon-optimizedwayofcheckingforprimenumbers:boolis_prime(intx){for(inti=2;ifut=std::async

C++11 Lambda 通过捕获传递

这个问题在这里已经有了答案:C++lambdawithcapturesasafunctionpointer(9个回答)关闭4年前。我正在尝试使用capture[&]传递lambda函数。存储捕获lambda的变量的正确声明是什么?[下面的f2]//Non-capturingvoid(*f1)()=[](){};//Works//Allbyreferencevoid(*f2)()=[&](){};//SyntaxError

c++ - XCode 6.1 - 缺少项目模板(C++ 库和 C++ STL 库)

昨天C++库和STLC++库模板突然从我的XCode6.1安装中消失了。它应该是这样的:现在是这样的:我完全卸载了XCode并重新安装了它,但仍然缺少这些模板。还有其他人遇到同样的问题吗?如何解决? 最佳答案 没关系!选择项目模板的用户界面在XCode6.1中发生了一些变化。以下是创建C++库项目的方法:要创建C++库,请选择库模板(甚至认为描述中说:“此模板构建链接到Cocoa框架的库”。它可能有点令人困惑,但您可以将其更改为C++库下一步)。单击“下一步”,然后您可以选择“框架类型”为“PlainC++Library”、“Coc

c++ - InterlockedExchangePointer 是否有裸露的 c++ 11(或 boost)替代品?

寻找Win32InterlockedExchangePointer的便携、简单和优雅的替代品。理想情况下仅使用C++11,但boost也可以。 最佳答案 standardatomictypes有一个原子exchange功能。所以微软人PVOIDvolatiletarget;old_value=InterlockedExchangePointer(&target,new_value);会变成std::atomictarget;old_value=target.exchange(new_value);

c++ - 在 C++11 中实现一个简单的通用线程池

我想创建一个线程池用于实验目的(以及有趣的因素)。它应该能够处理各种各样的任务(所以我可能会在以后的项目中使用它)。在我的线程池类中,我将需要某种任务队列。由于标准库提供了std::packaged_task由于C++11标准,我的队列看起来像std::deque>task_queue,所以客户端可以推送std::packaged_tasks通过某种公共(public)接口(interface)函数进入队列(然后池中的一个线程将收到条件变量通知以执行它,等等)。我的问题与std::packaged_task的模板参数有关在双端队列中。函数签名?()应该能够处理任何类型/数量的参数,因为

c++ - 我在 Xcode 中使用 C++11 时遇到一些问题

我是使用XcodeforC++的MacOSXLion用户,似乎没有适用于Xcode的更新。我似乎无法编译C++11专用代码,但无论出于何种原因,我认为Apple几乎已经实现了C++11。是的,我确实支持命令行工具。话又说回来,那可能只是我。如果是这样,是否有任何类型的IDE支持C++11,或者有什么升级方法? 最佳答案 我使用Xcode并设置了以下设置:C++语言方言:C++11或GNU++11C++标准库:libc++(支持C++11的LLVMC++标准库)Xcode版本:4.3.2

c++ - 在 C++11 中有一个基于反范围的 for 吗?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:C++11reverserange-basedfor-loopC++11中是否有基于反范围的for?我想做这样的事情:for(intvalue:vec){cout为此:for(autoit=vec.rbegin();it!=vec.rend();++it){cout例如:for(intvalue:-vec){cout是否可以做类似的事情来做一个反向循环?

c++ - 在 C++98 和 C++11 中访问枚举值

我在“Foo”类(如下)中定义了一组枚举值。namespaceFii{classFoo{structBar{enumBaz{BAZ1,BAZ2,BAZ3};};};};我正在使用一个结构来缩小Baz枚举值的范围,并显示有一组相关值。我的目标是将一个枚举类型的值赋给一个变量。使用上面的类定义,可以这样做:Fii::Foo::Bar::BazmyValue=Fii::Foo::Bar::BAZ1(WorksinbothC++98andC++11)但是,我觉得:乍一看,myValue似乎被初始化为一个Fii::Foo::Bar但这只是因为枚举是对父级(Bar在这种情况下)为了提高准备度,我将