草庐IT

thread_name

全部标签

c++ - C++11 可以判断 std::thread 是否处于事件状态吗?

令我惊讶的是,一个已完成执行但尚未加入的C++11std::thread对象仍然是considered一个活跃的执行线程。以下代码示例对此进行了说明(基于Xubuntu13.03和g++4.7.3)。有谁知道C++11标准是否提供了一种方法来检测std::thread对象是否仍在主动运行代码?#include#include#include#include#includeintmain(){autolambdaThread=std::thread([](){std::cout 最佳答案 不,我不认为这是可能的。我也会尝试考虑您的设计

C++/线程 : No instance of constructor "std::thread::thread" > matches the argument list

我在线程方面遇到了一些问题,因为我对它很陌生。我得到一个:noinstanceofconstructor"std::thread::thread"matchestheargumentlistargumenttypesare(void())恰好在std::threadt1(TestPlay);voidCMusicTCPDlg::OnBnClickedBtplaymusic(){std::threadt1(TestPlay);t1.join();}voidCMusicTCPDlg::TestPlay(){if(CFugue::GetMidiOutPortCount()我引用了一些线程页面,

c++ - 为什么用空函数运行 std::thread 会消耗大量内存

我写了一个简单的程序,它应该运行两个线程,对小数组(~4096字节)进行排序并写入输出文件。输入数据包含在一个大文件(~4Gb)中。电脑有128MB内存。我发现只运行空的主函数使用14MB内存。如果使用空函数应用程序运行std::thread,每个线程开始使用~8MB。但是如果我只制作一个动态内存分配程序,每个线程开始使用大约64Mb。我不明白什么可以花费这么多内存。我怎样才能控制这个尺寸?以及如何分配动态内存以最小化一些系统默认分配?系统:Ubuntu14.04.3编译器:gcc4.8.4编译器选项:'-std=c++11-O3-pthread'这是一个代码示例voiddummy(v

RT-Thread 软件包-软件包分类-IoT-OTA Downloader①

RT-Thread软件包-软件包分类-IoT-OTADownloader①RT-Thread软件包-软件包分类-IoT-OTADownloader①OTADownloader1、介绍1.1许可证1.2依赖2、如何打开OTADownloader3、使用OTADownloader3.1Ymodem协议固件升级命令行演示3.2HTTP/HTTPS协议固件升级命令行演示4、注意事项5、参考资料示例代码维护人:RT-Thread软件包-软件包分类-IoT-OTADownloader①OTADownloader中文页|英文页1、介绍本软件包是用于OTA升级的固件下载器,该下载器提供多种固件下载方式。开发者

C++11 std::this_thread::sleep_until() 在使用 GCC 4.8.5 编译时挂起

考虑以下程序:#include#includeintmain(){std::this_thread::sleep_until(std::chrono::steady_clock::now()-std::chrono::seconds(10));return0;}当用GCC4.8.5编译时,它会挂起。用GCC4.9及以上或clang3.4及以上编译时,立即返回,为什么会挂?据我了解,GCC4.8.5完全支持C++11标准。 最佳答案 这是一个已确认的错误,已在gcc4.9中修复。https://gcc.gnu.org/bugzilla

《Learning from Context or Names?An Empirical Study on Neural Relation Extraction》论文阅读笔记

代码原文地址预备知识:1.什么是对比学习?对比学习是一种机器学习范例,将未标记的数据点相互并列,以教导模型哪些点相似,哪些点不同。也就是说,顾名思义,样本相互对比,属于同一分布的样本在嵌入空间中被推向彼此。相比之下,属于不同分布的那些则相互拉扯。摘要神经模型在关系抽取(RE)的基准任务上表现出色。但是,我们还不清楚文本中哪些信息对现有的RE模型的决策有影响,以及如何进一步提升这些模型的性能。为了解决这个问题,本文实证地分析了文本中两个主要的信息源:文本上下文和实体提及(名称)对RE的作用。本文发现,虽然上下文是预测的主要依据,但RE模型也高度依赖于实体提及中的信息,其中大多数是类型信息;以及现

c++ - boost::threads 执行顺序

我对连续创建的线程的执行顺序有疑问。这是代码。#include#include#includeusingnamespacestd;boost::mutexmutexA;boost::mutexmutexB;boost::mutexmutexC;boost::mutexmutexD;voidSomeWork(charletter,intindex){boost::mutex::scoped_locklock;switch(letter){case'A':lock=boost::mutex::scoped_lock(mutexA);break;case'B':lock=boost::mut

c++ - 混合 std::move() 和 std::thread 不会编译

代码如下:#include#includeclassA{voidfoo(int&&arg)const{}voidboo()const{intvalue(0);std::threadt(&A::foo,this,std::move(value));t.join();}};intmain(){Aa;return0;}MSVisualStudio2012(工具集v110)给出下一个错误:errorC2664:'_Rxstd::_Pmf_wrap::operator()(const_Wrapper&,_V0_t)const':cannotconvertparameter2from'int'to

c++ - 为什么 std::thread 采用右值运行的函数?

std::thread有一件事我不明白:为什么std::thread的构造函数采用右值运行的函数?我通常想将具有一些成员的Functor运行到另一个线程。像这样:structFunction{voidoperator()(/*someargs*/){/*somecode*/}/*somemembers*/}voidrun_thread(){Functorf(/*somedata*/);std::threadthread(f,/*somedata*/);/*dosomethingandwaitforthreadtofinish*/}随着std::thread的当前实现,我必须确保我的对象

c++ - curl_easy_perform : Couldn't resolve host name

我在使用libcurl时遇到了一些奇怪的问题-它拒绝解析特定的URL,返回错误消息“无法解析主机名”。解决其他主机没有问题。我怀疑原因是失败的URL返回了302重定向,但我已经设置了适当的选项以供遵循。有问题的网址:http://servermods.cursecdn.com/files/922/48/worldedit-bukkit-6.1.3.jar相关代码:CURL*curl;FILE*data;std::stringurl;//...curl_easy_setopt(curl,CURLOPT_WRITEFUNCTION,write_callback);curl_easy_set