草庐IT

scoped_thread

全部标签

c++ - `unique_lock`、 `scoped_lock` 和 `lock_guard` 中指定的 mutex_type 的用例是什么?

用于保护std::mutex的c++11mutexRAII类型都有一个typedef:typedefMutexmutex_type;std::lock_guard::mutex_typestd::unique_lock::mutex_typestd::scoped_lock::mutex_type这个成员typedef有什么意义?起初我认为它可以用来概括创建一个对象来移动锁(在unique_lock的情况下)例如:templatevoidfunction(SomeLockin)SomeLock::mutex_typenewMutex;//Dosomething但我无法想象它的用途。需要

c++ - boost asio : different thread pool for different tasks

网络上有很多关于创建简单线程池的示例,例如Sample1和Sample2虽然我想要实现的是为不同的任务提供一个单独的线程池。例如,应用程序可能有一个线程池用于处理传入的tcp连接(我们称之为网络池),而另一个线程池用于与数据库(数据库池)对话。这些传入的tcp请求可能需要来自数据库的信息。在这种情况下,它需要请求数据库池中的那些线程执行查询,并异步返回结果。是否有使用boost::asio的推荐方法?每个池都有一个io_service实例吗?这些线程应该如何相互通信(使用boost)?我明白要解释所有这些,代码不会那么短和琐碎,但如果可能的话,一些伪代码将不胜感激。谢谢!

c++ - boost::thread 和 std::thread 兼容性问题?

我有一个关于将boost::threads与一些c++11标准项目混合和匹配的问题,这行得通吗?我实际上还没有测试任何东西,但我正在使用一个系统,该系统使用所有boost::threads和线程组以及中断功能,这些功能在标准中没有开箱即用,因此没有变化。我们的boost1.50版本没有最新的std::atomic和内存排序的东西。我想知道我是否可以将std::atomic和std::内存排序操作load/fectch_add等(获取/释放,放松)与boost线程一起使用,并获得与std::thread相同的结果。这些都是我linux机器上的pthreads,所以我认为答案是肯定的,我可

c++ - OpenMP:不要使用超线程内核(一半 `num_threads()` w/超线程)

在IsOpenMP(parallelfor)ing++4.7notveryefficient?2.5xat5xCPU,我确定当使用默认的#pragmaompparallelfor时,我的程序的性能在11s和13s之间变化(大多数总是高于12s,有时慢到13.4s),CPU使用率约为500%,在4核8线程Xeon上,OpenMP加速仅为2.5倍,在5倍CPUw/g++-4.7-O3-fopenmp上。我尝试使用schedule(static)num_threads(4),并注意到我的程序总是在11.5秒到11.7秒(总是低于12秒)内完成,CPU使用率约为320%,例如,运行更多始终如一

c++ - 场景 : Global variables in DLL which is used by Multi-threaded Application

几个月前,我遇到了一个人(在orkut上)问的这个有趣的场景。虽然,我已经针对这个问题提出了一个“不可移植”的解决方案(已经用小代码对其进行了测试),但仍然想知道你们有什么要说的和建议的。假设,我创建了一个DLL,导出一些功能,用C++编写,用于单线程客户端。这个DLL声明了很多全局变量,一些可能是const变量(只读),其他的是可修改的。无论如何,后来情况发生了变化,现在我希望同一个DLL与多线程应用程序一起工作(无需修改DLL);这意味着,多个线程从DLL访问函数和全局变量,并修改它们……等等。所有这些都可能导致全局变量持有不一致的值。所以问题是,我们能否在客户端代码中做一些事情来

c++ - 带有指向数据成员的指针的 std::thread

我正在阅读std::threaddocumentationatcppreference(并不总是100%准确,我知道)并注意到当传递“指向数据成员的指针”(不是“指向成员的指针”)时std::thread的行为的以下定义-function")作为它的第一个参数(f)和一个所需类的对象作为它的第二个参数(t1在复制到thread-local-storage之后):IfN==1andfispointertoamemberdataobjectofaclass,thenitisaccessed.Thevalueoftheobjectisignored.Effectively,thefollow

c++ - 表达式不是积分常量 clang libc++ threading

我试图在我的linux机器(ubuntu)上编译一个非常简单的线程程序,但即使我指定了libc++,clang似乎仍然向我抛出错误。我的程序是:#include#includevoidcall_from_thread(){std::cout生成文件:CC=clang++CFLAGS=-std=c++11-stdlib=libc++-pthread-c-Wall#properdeclarationoflibc++,butstillanerror...LDFALGS=SOURCES=main.cppOBJECTS=$(SOURCES:.cpp=.o)EXECUTABLE=bimapall:

c++ - boost::thread 变量的前向声明

有人可以告诉我我们可以转发声明一个boost::thread变量吗?boost::线程t(线程);启动一个线程,但我想在某处声明它并在其他地方启动它。提前谢谢。当我使用boost::threadt;t=boost::thread(thread);/usr/include/boost/noncopyable.hpp:Incopyconstructor‘boost::thread::thread(constboost::thread&)’:/usr/include/boost/noncopyable.hpp:27:error:‘boost::noncopyable_::noncopyabl

c++ - std::scoped_allocator_adaptor 和一个使用 std::allocator_arg_t 构造函数的类

我在这里找到了一些词http://en.cppreference.com/w/cpp/memory/scoped_allocator_adaptor/constructifstd::uses_allocator::value==true(thetypeTusesallocators,e.g.itisacontainer)andifstd::is_constructible::value==true,thencallsstd::allocator_traits::construct(OUTERMOST(*this),p,std::allocator_arg,inner_allocator

C++ 错误 : was not declared in this scope with private after public

试图修改来自thispage的代码.问题代码如下:#include#includetemplateclassconst_reverse_wrapper{public:const_reverse_wrapper(constT&cont):container_(cont){}decltype(container_.rbegin())begin()const{returncontainer_.rbegin();}decltype(container_.rend())end(){returncontainer_.rend();}private:constT&container_;};templ