草庐IT

thread_func

全部标签

c++ - 我什么时候需要使用 std::async(std::launch::async, func()) 而不是 func()?

我不明白使用std::async的原因与std::lauch::async标志,而不是简单地调用传递给std::async的函数.是否有任何特价保证? 最佳答案 根据thedocumentation,是一个只接受函数及其参数的重载。您正在使用接受更具体的策略的重载。async(f,args...)等同于async(std::launch::async|std::launch::deferred,f,args...),其中两个标志的存在将函数是否简单地与当前调用堆栈分离(推迟到第一个非定时等待函数的执行;这称为惰性求值),或者实际上是

Java多线程-线程的创建(Thread类的基本使用)

文章目录一.线程和Thread类1.线程和Thread类1.1Thread类的构造方法1.2启用线程的相关方法2.创建第一个Java多线程程序3.使用Runnable对象创建线程4.使用内部类创建线程5.使用Lambada表达式创建线程6.多线程并发执行简单演示7.多线程并发执行的优势二.Thread类的属性与方法1.Thread类中的重要属性2.Thread类中常用方法总结2.1常用方法2.2中断线程2.3线程等待2.4线程调用start和直接调用run的区别三.Java线程的状态1.Java线程中的基本状态2.线程的状态转移在Java中如何进行多线程编程呢?关于线程的操作,操作系统是提供了

c++ - 什么是 A B::* func() 定义?

一个现已删除的问题与此类似:structA{};structB{Aread();};AB::*read(){returnA{};}这段代码会报错:error:cannotconvert‘A’to‘AB::*’inreturnreturnA{};正如我们所见,这不是read()的类外定义,而是定义了一个返回AB::*的非成员函数.在这种情况下,AB::*到底是什么? 最佳答案 AB::*表示“指向B的数据成员,类型为A。例如:structB{Ax;};...Bb;AB::*ptr=&B::x;//ptristhevariabledec

c++ - 读取大文件时杀死 std::thread

我有一个std::thread函数调用fopen将一个大文件加载到一个数组中:voidloadfile(char*fname,char*fbuffer,longfsize){FILE*fp=fopen(fname,"rb");fread(fbuffer,1,fsize,fp);flose(fp);}调用者:std::threadloader(loadfile,fname,fbuffer,fsize);loader.detach();在某些时候,我的程序中的某些东西想要停止读取该文件并请求另一个文件。问题是当我删除fbuffer指针时,loader线程仍在运行,我得到了一个引发异常的竞争

c++ - Valgrind 下 Mac OS 上的 std::thread.join() SIGSEGV

以下简单代码(C++11)将仅在MacOS和Linux上运行:#include#include#includevoidthreadFunction(){for(intcc=0;cc但是,在Valgrind中包装执行:valgrind--leak-check=full--show-reachable=no--track-fds=yes--error-exitcode=1--track-origins=yes./theexecutable...它现在可以在Linux上运行,但不能在MacOSX上运行,失败:==47544==Processterminatingwithdefaultacti

c++ - std::thread vs pthread,我做错了什么?

我正在从事一个需要在docker容器内执行某些进程的项目。我想处理进程没有按时终止的情况(比如说在10秒内)。我正在使用这个DockerClientpp用于管理基本上只向Docker套接字发出HTTP请求的容器的库。到目前为止一切都很好。要停止花费太长时间的容器,我使用了一个单独的线程。问题是我能够使用ptheads来实现它,但是我找不到使用std::thread和lambas的方法这是我使用pthread的工作实现void*ContainerManager::spawnKiller(void*ref){ContainerManager*self=(ContainerManager*)

c++ - Boost::thread 如何获取指向调用我的函数的线程的指针?

使用boost::thread我如何从该函数中获取指向当前正在执行我的函数的boost::thread的指针?以下不适合我编译:boost::thread*currentThread=boost::this_thread; 最佳答案 你必须小心,因为boost::thread是可移动类型。请考虑以下事项:boost::threadmake_thread(){boost::threadthread([](boost::thread*p){//hereppointstothethreadobjectwestartedfrom},&thr

c++ - std::thread 的线程安全数组?

mystruct**=(mystruct**)calloc(10,sizeof(mystruct*);for(unsigndinti=0;i函数new_piece将数据写入mystruct[i]。更具体地说,该函数更改了mystruct[i][0],mystruct[i][1],...,mystruct[9]的值如何让上面的操作线程安全? 最佳答案 正如评论中已经提到的,该代码似乎是“线程安全的”,但它可能会遭受“缓存抖动”的困扰。首先让我解释一下它是什么,以及为什么这可能会在您的代码中发生:什么是缓存抖动:“缓存行”是从内存中提取

c++ - std::thread 在 DLLMain 中导致死锁

所以,这就是我要说的:std很复杂。在VS2013中这个简单的程序会导致死锁。#include#includevoidfoo(){}voidinitialize(){std::threadt(foo);}BOOLAPIENTRYDllMain(HMODULE,DWORDreason,LPVOID){switch(reason){caseDLL_PROCESS_ATTACH:initialize();break;caseDLL_THREAD_ATTACH:break;caseDLL_THREAD_DETACH:break;caseDLL_PROCESS_DETACH:break;}ret

c++ - block 范围内的 thread_local

thread_local变量在block范围内有什么用?如果一个可编译的样本有助于说明问题,这里是:#include#includenamespaceMy{voidf(int*constp){++*p;}}intmain(){thread_localintn{42};std::threadt(My::f,&n);t.join();std::cout输出:43在示例中,新线程获得了它自己的n但(据我所知)不能用它做任何有趣的事情,所以何必呢?新线程自己的n有没有用?如果它没有用,那又有什么意义呢?自然地,我假设是一个点。我只是不知道这有什么意义。这就是我问的原因。如果新线程自己的n想要(