草庐IT

libboost_thread-vc

全部标签

c++ - 分离的 std::thread 终止后是否需要删除?

我创建了一个newstd::thread对象,然后detach()它。线程运行任意时间,然后自行终止。由于我使用new创建了对象,我是否需要在某个时候delete来释放它的资源?还是线程在终止时有效地删除自身?如果它确实有效地删除自身,如果我在它终止后显式删除它,是否会发生不好的事情? 最佳答案 是的,你必须自己删除它。一旦您调用std::thread::detach,线程将与线程对象分离并允许独立执行,然后线程对象将不再拥有任何线程。所以线程不会也不可能在终止时删除它。 关于c++-分

c++ - 具有协变返回类型的方法在VC++上崩溃

使用clang或gcc(在macOS上)编译时,以下代码似乎运行良好,但使用MSVisualC++2017编译时,以下代码崩溃。foo_clone->get_identifier()。如果删除协变返回类型(所有克隆方法都返回IDO*),删除std::enable_shared_from_this或将所有继承设为虚拟,则它在VC++上确实有效。为什么它可以与clang/gcc一起使用,但不适用于VC++?#include#includeclassIDO{public:virtual~IDO()=default;virtualconstchar*get_identifier()const=

c# - 我们如何在 VC++ 中使用 .NET dll?

请建议我在VC++项目中使用.NETdll的最佳方法。 最佳答案 使其可见。参见linktext 关于c#-我们如何在VC++中使用.NETdll?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1802929/

c++ - Boost.Thread 还是::thread?

我还不是Boost用户。然而,我打算尽快进入它。然而,我不太关心Boost,以及future可能与即将推出的C++0x发生名称冲突或差异。(也许这不是一个真正的问题,但例如我发现boostlambdas语法非常丑陋,BOOST_FOREACH对眼睛有侵略性,以及其他仅个人审美观点)。我对TR2很感兴趣,它似乎是由库实现的Boost.Thread和just::thread.两者似乎都是由AnthonyWilliams编写和维护的。但是just::thread声称非常符合TR2。我想知道你们中是否有人会指示我使用一个或另一个。just::thread不是免费的,但如果它真的像TR2一样,我

c++ - 为什么 VC++ 2010 允许编译?

std::vectorvci;vci.push_back(1);vci[0]=2;如果元素类型是constint,赋值语句不应该赋值给constint&吗?这不会用LLVM3.0编译。为什么VC++允许它? 最佳答案 虽然它是未定义的行为并且基本上任何都可能发生,包括您所看到的,但我已经追踪到这似乎是库与标准不兼容的地方。特别是VS2010库中定义的标准分配器不符合标准。标准规定std::vector::value_type是Allocator::value_type的类型定义.现在默认分配器(如果没有提供)是std::alloca

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++ - 在 VC2015 中连接不匹配的字符串 WORKS - 如何?

当我们有这些之一时:autocity1="New"L"Delhi";autocity2=L"New""York";任何VS2015之前的编译器都会引发错误:errorC2308:concatenatingmismatchedstrings但是使用VC2015编译器,它编译得很好并且结果类型(auto推导)是一个宽字符字符串。我的问题是:何时以及如何做到这一点-任何标准规范? 最佳答案 在C++03中,此行为是未定义的。ISO14882-2003:2.13.4.3指出Intranslationphase6(2.1),adjacentn

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升级的固件下载器,该下载器提供多种固件下载方式。开发者