[英]Is it smart to replace boost::thread and boost::mutex with c++11 equivalents?
[英]Is it safe to mix boost::thread with C++11 std::mutex?
在通过 boost 启动其线程的程序中使用std::mutex
及其亲属是否安全?
(使用std::thread
不是我的选择(我认为),因为应用程序需要大量堆栈空间,并且在某些平台上需要在创建时覆盖默认堆栈大小。)
是的,您可以在使用boost::thread
创建的线程中使用std::mutex
。
应用程序需要大量堆栈空间,并且在某些平台上需要在创建时覆盖默认堆栈大小
std::thread
使用pthread_create
在支持 POSIX 的平台上创建线程。 您的另一个选择是覆盖pthread_create
,设置堆栈大小并调用原始pthread_create
。
一个有效的 Linux 示例(我无法访问 MacOS 以在那里尝试):
#include <cstdio>
#include <thread>
#include <dlfcn.h>
namespace {
size_t const STACK_SIZE = 8 * 1024 * 1024;
int pthread_create_override(pthread_t* thread, pthread_attr_t const* attr, void*(*start_routine)(void*), void* arg) noexcept {
std::printf("%s\n", __PRETTY_FUNCTION__);
pthread_attr_t attr2;
if(attr)
attr2 = *attr;
else
if(pthread_attr_init(&attr2))
std::abort();
size_t stacksize = 0;
pthread_attr_getstacksize(&attr2, &stacksize);
if(stacksize < STACK_SIZE) {
if(pthread_attr_setstacksize(&attr2, STACK_SIZE))
std::abort();
}
static auto const real_pthread_create = reinterpret_cast<decltype(&pthread_create)>(::dlsym(RTLD_NEXT, "pthread_create"));
int rc = real_pthread_create(thread, &attr2, start_routine, arg);
if(!attr)
pthread_attr_destroy(&attr2);
return rc;
}
} // namespace
extern "C" {
int pthread_create(pthread_t* thread, pthread_attr_t const* attr, void*(*start_routine)(void*), void* arg) {
return pthread_create_override(thread, attr, start_routine, arg);
}
} // namespace
int main() {
std::thread t([]() { std::printf("%s\n", __PRETTY_FUNCTION__); });
t.join();
}
输出:
int {anonymous}::pthread_create_override(pthread_t*, const pthread_attr_t*, void* (*)(void*), void*)
main()::<lambda()>
您启动线程的方式( pthread_create
、 boost::thread
、 std::thread
)与您使用的同步原语正交( std
vs boost
vs Intel TBB vs libatomic vs etc..)。
否则,您将无法在一个应用程序中混合和匹配使用这些不同 API 的库。
原子、互斥体和条件变量等低级同步原语可以放置在共享内存中,供不同进程使用,而根本无需显式创建任何额外线程。 以及主应用程序线程是由操作系统内核为您创建的,而无需使用任何用户空间 API。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.