草庐IT

task_info

全部标签

c++ - type_info 不是 RTTI 的一部分吗?

我问了一个问题DoC++PODtypeshaveRTTI?有人在评论中告诉我:PODtypesdohavetype_info,butdon'thaveRTTI,andthat'spossiblebecausetype_infoisn'talwaysRTTI.这似乎是正确的,因为我可以获得POD(非多态)类型的type_info。但是当我编译这个简单的程序时:#includestructX{inta;};intmain(){usingnamespacestd;std::cout带有GCC的标志-fno-rtti:$g++-fno-rttimain.cpp&&./main它不会编译:mai

c++ - boost::exception_detail::clone_impl<boost::exception_detail::error_info_injector<boost::thread_resource_error>>

我需要一些帮助来解决这个异常,我正在实现一个NPAPI插件,以便能够使用来自浏览器扩展的本地套接字,为此我正在使用Firebreath框架。对于套接字和连接,我使用带有异步调用的Boostasio和一个包含5个工作线程的线程池。我还为每个线程设置了截止日期以实现传输超时。我使用插件的扩展工作流程是这样的:打开套接字1(这会启动async_receive和截止时间异步等待)写入套接字1获取响应1打开另一个socket2在套接字2中写入写套接字1关闭套接字1(socket.cancel(),deadline.cancel(),socket.shutdown(),socket发布)。获取响应

c++ - typeid/type_info 奇怪的行为

为什么下面的例子:#include#includetemplatevoidfun(constT¶m){std::cout给出以下输出:Tisiparamisi1我知道type_info::name()行为依赖于实现。无论如何,我希望operator==返回false(因为param是一个const引用,而不是一个整数)。 最佳答案 这是在标准中定义的:5.2.8/5:Ifthetypeoftheexpressionortype-idisacv-qualifiedtype,theresultofthetypeidexpress

c++ - 为什么 type_info::name() 未指定?

我完全知道std::type_info::name()的返回值是实现定义的。来自C++标准(ISO/IEC14882:2003§18.5.1.7):Returns:animplementation-definedNTBS.我的问题是:为什么?如果标准规定了返回值应该是什么,这个成员函数不是更有用吗? 最佳答案 基本上,如果一个实现决定他们不能或不想支持RTTI,他们可以return"";。如果标准强制它返回某些东西,他们可能会扼杀任何为RTTI资源不存在或想要禁用的环境(例如微芯片)提供兼容编译器的能力。别忘了我们不想在任何编译器上

c++ - 如何创建带参数的 packaged_task?

正在关注thisexcellenttutorial对于futures、promises和打包任务,我到了要准备自己的任务的地步#include#includeusingnamespacestd;intackermann(intm,intn){//mighttakeawhileif(m==0)returnn+1;if(n==0)returnackermann(m-1,1);returnackermann(m-1,ackermann(m,n-1));}intmain(){packaged_tasktask1{&ackermann,3,11};//就我能破译gcc-4.7.0错误消息而言,它

android - 无法为 org.gradle.api.internal.tasks.DefaultSourceSetContainer 类型的 SourceSet 容器获取未知属性 'main'

首先,我只是想让AspectJ获取我编译的Kotlin类。在尝试执行此操作时,我遇到了一篇文章,说OP能够通过将其添加到其模块build.gradle的末尾来让AspectJ获取Kotlin文件:sourceSets.main.output.classesDir=sourceSets.main.output.classesDir.toString().replace("java","kotlin")但这给了我一个错误:Couldnotgetunknownproperty'main'forSourceSetcontaineroftypeorg.gradle.api.internal.ta

android - 无法为 org.gradle.api.internal.tasks.DefaultSourceSetContainer 类型的 SourceSet 容器获取未知属性 'main'

首先,我只是想让AspectJ获取我编译的Kotlin类。在尝试执行此操作时,我遇到了一篇文章,说OP能够通过将其添加到其模块build.gradle的末尾来让AspectJ获取Kotlin文件:sourceSets.main.output.classesDir=sourceSets.main.output.classesDir.toString().replace("java","kotlin")但这给了我一个错误:Couldnotgetunknownproperty'main'forSourceSetcontaineroftypeorg.gradle.api.internal.ta

c++ - 使用 std::packaged_task 时 std::future 仍然延迟(VS11)

看来除非你调用std::async一个std::future绝不会设置为除future_status::deferred以外的任何其他状态除非你调用get或wait关于future。wait_for&wait_until将继续不阻塞并返回future_status::deferred即使任务已经运行并存储了结果。这是一个例子:#includevoidmain(){autofunc=[](){return5;};autoasyncFuture=std::async(std::launch::async,func);autostatus=asyncFuture.wait_for(std::

c++ - std::function 和 std::packaged_task 转换

我正在尝试移动std::packaged_task进入std::vector的std::function,因为std::packaged_task有voidoperator()(ArgTypes...args)过载,它应该可以转换为std::function,是的?这不会在MSVC和Clang上编译,MSVC提示无法将void转换为int,clang提示删除了std::packaged_task的复制构造函数|,不应移动std::vector::push_back的版本被叫到这里?这是怎么回事,这是一个错误吗?intmain(){std::vector>vec;std::package

c# - 如果模态对话框打开,Task.Factory.StartNew() 在错误的线程上运行

谁能解释为什么,如果C++应用程序运行一个.NETUI组件(全部在主线程上),它又生成一个模态.NET对话框,然后尝试使用TaskScheduler.FromCurrentSynchronizationContext();Task.Factory.StartNew调用中的任务是否在工作线程上运行?如果我不显示对话框或在显示对话框之前存储上下文,则不会发生这种情况。我试图创建一个虚拟程序来显示它但失败了,我认为这可能与主进程是COM有关。有什么想法吗?好的,我的代码是这样的privatevoidRunStateMachine(IQ4UpgraderStateState){_State=S