草庐IT

last_lock_in_thread

全部标签

c++ - async([](){}) 和 thread([](){}).detach() 有什么区别?

下面两个语句在执行方面有什么区别?async([](){...});thread([](){...}).detach(); 最佳答案 std::async([](){...});//(1)std::thread([](){...}).detach();//(2)大多数情况下,当std::async被讨论时,首先注意到的是它被破坏了,这个名字暗示了当返回值不被接受时不成立的东西(分配给要在当前作用域结束时销毁的变量)。在这种情况下,std::async的中断正是导致(1)和(2);一个会阻止,另一个不会。为什么std::async会在

c++ - 创建 std::thread c++11 时收到的 SIGABRT 信号

我在这样的类成员方法中创建了一个线程:voidMyClass::startThread(){T.reset(newstd::thread(&MyClass::myThreadMethod,this));}voidMyClass::myThreadMethod(){//...}在哪里//Inheaderfilestd::unique_ptrT;当我运行MyClass::startThread()时,我收到:收到信号:SIGABRT(中止)...如果我单步执行代码,它会发生在线程构造函数中。我试图像这样删除unique_ptr:voidMyClass::startThread(){std:

c++ - vector 中的“one-past-the-last-element”是什么意思?

我正在学习vector,对数组如何复制到此处的vector感到困惑doublep[]={1,2,3,4,5};std::vectora(p,p+5);我也知道std::vectora(3,5);意思是`为3腾出空间并用5初始化它们。上面的代码是如何工作的?第二点是我阅读了我复制上述代码的段落。Understandingthesecondpointiscrucialwhenworkingwithvectorsoranyotherstandardcontainers.Thecontrolledsequenceisalwaysexpressedintermsof[first,one-past

c++ - 将参数传递给 std::thread 包装器

我想实现一个小型线程包装器,用于提供线程是否仍处于事件状态或线程是否已完成其工作的信息。为此,我需要将线程类要执行的函数及其参数传递给另一个函数。我有一个应该可以工作但无法编译的简单实现,而且我不知道该怎么做才能让它工作。这是我的代码:#include#include#include#include#includeclassManagedThread{public:templateexplicitManagedThread(Function&&f,Args&&...args);boolisActive()const{returnmActive;}private:volatilebool

c++ - boost 共享指针 : Simultaneous Read Access Across Multiple Threads

我有一个线程A,它分配内存并将其分配给一个共享指针。然后该线程生成另外3个线程X、Y和Z,并将共享指针的拷贝传递给每个线程。当X、Y和Z超出范围时,内存将被释放。但是是否有可能2个线程X、Y在完全相同的时间点超出范围并且引用计数存在竞争条件,因此它不会将其递减2,而只会递减一次。所以,现在引用计数newer下降到0,所以存在内存泄漏。请注意,X、Y和Z仅读取内存。不写入或重置共享指针。长话短说,引用计数是否存在竞争条件,这会导致内存泄漏吗? 最佳答案 boost::shared_ptr使用锁(或无锁原子访问)来确保引用计数以原子方式

c++ - undefined reference `pthread_create' 使用 ASIO 和 std::thread 制作 C++11 应用程序时出错

我设置了Eclipse(实际上是XilinxSDK,但基于Eclipse)和g++4.9.2来编译一个使用独立ASIO的项目,我在属性->C/C++中使用了-std=c++11Build->Settings->ToolSettings->Otherflags以便它可以使用所有C++11特性进行编译。我还在C/C++GeneralSymbols中设置了ASIO_HAS_STD_THREAD,ASIO_STANDALONE等等,我希望ASIO头文件会使用std::thread而不是线程。但是,我仍然看到来自make的错误:undefinedreferencetopthread_create

初学者使用Xcode的一些问题解决,以及A function declaration without a prototype is deprecated in all versions of C处理

今天我使用Xcode创建了一个项目,并在其中生成了一个.c文件。这个文件运行起来没有问题,于是我生成了第二个.c文件,发现编译错误。原因是Xcode每个target都只能有一个main函数,如果需要在一个项目内创建互不影响的小项目,应该使用创建target的方式,否则会报错。另外还有一个问题:许多c的教程中主函数会这么写intmain(){}事实上这在Xcode中是会提示错误的,具体报错为:AfunctiondeclarationwithoutaprototypeisdeprecatedinallversionsofC这是因为在c语言中,没有参数的函数括号内要写void,这是唯一正确的写法,不

c++ - 奇怪的 gcc 错误 : stray '\NNN' in program

我的开源库中弹出了以下问题,我无法弄清楚发生了什么。我的两个用户有类似的(gcc)编译器错误:/home/someone/Source/src/._regex.cpp:1:1:warning:nullcharacter(s)ignored/home/someone/Source/src/._regex.cpp:1:error:stray‘\5’inprogram/home/someone/Source/src/._regex.cpp:1:error:stray‘\26’inprogram/home/someone/Source/src/._regex.cpp:1:error:stray

c++ - "Cannot appear in a constant expression",我需要它作为一个变量,为什么它不让我这样做?

stringconvert_binary_to_hex(stringbinary_value,intnumber_of_bits){bitsetset(binary_value);ostringstreamresult;result在上面的方法中,我将二进制字符串转换为十六进制字符串。由于十六进制值是4位,number_of_bits变量需要是4的倍数,因为对于我正在编写的应用程序,binary_value的范围可能在4位到256位之间.如何让bitset的大小可变?我的导入:#include#include#include#include#include

c++ - IN/OUT 参数以及如何在 C++ 中使用它们

当从不同类型的外部库中阅读有关函数的文档时,我总是看到文档声明变量必须是[IN/OUT]。有人可以详细了解[IN/OUT]与通过引用或值传递的函数参数的关系吗?这是我遇到的一个函数示例,它告诉我它需要一个[IN/OUT]参数:原型(prototype):ULONGGetActivationState(ULONG*pActivationState);参数类型:ULONG*变量:pActivationState模式:输入/输出 最佳答案 这部分适用于所有类型的参数-大多数库接口(interface)都试图与C兼容,因此更常见的是通过指针