草庐IT

THREAD_SIZE

全部标签

C++ "new T[size]"不起作用?

我有一个模板类定义为:#include#includeusingnamespacestd;templateclasstbufferpool{private:constintm_initial;constintm_size;constintm_total;T*m_buffer;vectorm_queue;public://constructortbufferpool(intinitial,intsize):m_initial(initial),m_size(size),m_total(initial*size){m_buffer=newT[m_total];T*next_buffer=m

c++ - 从 native 句柄创建 std::thread?

如果我有一个std::thread对象t,我可以使用t.native_handle()来访问API底层线程实现(例如,pthreads或Windows线程)。但是,如果我有一个来自底层线程实现的句柄(例如,一个pthreads线程)怎么办?有什么方法可以将其转换为C++11std::thread?这样做的动机是可能需要使用native平台线程API来设置线程,例如,具有特定的亲和性或特定的堆栈大小(或无法通过C+访问的其他一些特征)+11API)。然而,从那时起,最好坚持使用C++11功能。有什么办法吗? 最佳答案 使用GCC,您可

c++ - 为什么thread_local不能应用于非静态数据成员以及如何实现线程局部非静态数据成员?

为什么thread_local不能应用于非静态数据成员?thisquestion的公认答案说:“将非静态结构或类成员设为线程本地是没有意义的。”老实说,我看到很多很好的理由让非静态数据成员成为线程本地的。假设我们有某种ComputeEngine,其成员函数computeSomething被连续调用多次。成员函数内部的一些工作可以并行完成。为此,每个线程都需要某种ComputeHelper来提供辅助数据结构等。所以我们真正想要的是:classComputeEngine{public:intcomputeSomething(Argsargs){intsum=0;#pragmaomppara

c++ - Visual Studio 2017 : ambiguous symbol size_t in linux projects

在VisualStudio2017中创建Linux项目并在源代码中插入usingnamespacestd;时,如下所示:#include#includeusingnamespacestd;intmain(){size_ti=1;strings=to_string(i);coutVS下划线size_t说是有歧义的符号。如果我按F12(转到定义),它会为我提供两个定义位置:来自stddef.h(C:\ProgramFiles(x86)\MicrosoftVisualStudio14.0\VC\Linux\include\usr\include\x86_64-linux-gnu\5\incl

c++ - 为什么 unordered_set 操作像计数和删除返回一个 size_type?

显然,unordered_set::erase和unordered_set::count返回一些不是严格bool值的东西(从逻辑上讲,也就是说,我不是在谈论实际类型)。链接页面读取第三个版本的删除:size_typeerase(constkey_type&key);Removestheelementswiththekeyvaluekey这有一种语气,表明可能不止一个元素具有给定的键。它没有明确说明这一点,但听起来很像。现在,集合(即使是无序集合)的要点是每个元素都有一次。标准库承认bool类型的存在并将其用于bool值,如unordered_set::empty().那么,在上述情况下

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

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

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++ - 为什么我得到 "cannot allocate an array of constant size 0"?

这个问题在这里已经有了答案:WhathappensifIdefinea0-sizearrayinC/C++?(8个答案)关闭8年前。我正在为学校做一个扫雷程序,但我的代码中一直出现这个错误cannotallocateanarrayofconstantsize0我不知道为什么会这样;我没有分配大小——我将它设置为0。另一个问题是,我如何通过char读取我的输入char,这样我就可以将它保存在我的数组?正如您在下面看到的,我正在使用输入和输出。我评论了我的输入和输出,这样你们就可以看到我在这个程序中使用了什么。我想通过char读取char,这样我就可以将所有map保存在数组中。我正在使用M

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++ - 为什么 std::allocator<>::deallocate() 有一个未使用的 size_type 参数?

使用std::allocator时,deallocate函数需要pointer参数,和一个size_type参数(std::allocator::deallocate(std::allocator::pointerp,std::allocator::size_type)。但是,没有使用size_type,也不是可选的。那么为什么它在那里?这让我很困惑,因为它应该是可选的,甚至不在那里,因为它没有在函数中使用.编辑:MSVC的分配器实现deallocatevoiddeallocate(pointer_Ptr,size_type){//deallocateobjectat_Ptr,igno