将boost :: thread与C++ 11 std :: mutex混合使用是否安全?

Chr*_*pka 8 c++ multithreading boost c++11

std::mutex在通过boost启动其线程的程序中使用它和它的亲属是否安全?

(使用std::thread对我来说不是一个选项(我认为),因为应用程序需要大量的堆栈空间,并且在某些平台上需要在创建时覆盖默认的堆栈大小.)

Max*_*kin 0

应用程序需要大量堆栈空间,并且在某些平台上需要在创建时覆盖默认堆栈大小

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();
}
Run Code Online (Sandbox Code Playgroud)

输出:

int {anonymous}::pthread_create_override(pthread_t*, const pthread_attr_t*, void* (*)(void*), void*)
main()::<lambda()>
Run Code Online (Sandbox Code Playgroud)