Почему этот простой пример многопоточности C++11 не работает при компиляции clang 3.2?
Я не могу понять, что я делаю здесь не так. Это очень короткая программа:
#include <iostream>
#include <string>
#include <atomic>
#include <thread>
using namespace std;
int
main(int argc, char ** argv)
{
thread foo( []() {
cout << "Hello World" << endl;
return 0;
} );
foo.join();
return 0;
}
Он отлично работает при компиляции с gcc (4.7.2)
:
$ g++ -ggdb -std=c++11 -pthread -o clang_thread_test clang_thread_test.cpp
$ ./clang_thread_test
Hello World
Однако при компиляции с clang (3.2; x86_64-pc-linux-gnu; thread model: posix)
он не может выполнить:
$ clang++ -ggdb -std=c++11 -pthread -o clang_thread_test clang_thread_test.cpp
$ ./clang_thread_test
pure virtual method called
terminate called without an active exception
Aborted
Есть ли известная причина для этого? Единственное, что я нашел, было связано с пропавшим без вести. -pthread switch
или не используется libc++
, Насколько мне известно, последнее относится только к системам Apple.
1 ответ
Подтвердили, что это работает:
clang++ --std=c++11 -pthread -D__GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 -D__GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 -D__GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 -D__GCC_HAVE_SYNC_COMPARE_AND_SWAP_8
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=53841
исправлена ошибка в хронологической теме:
linux error: no matching constructor for initialization of 'duration'
используя предлагаемое исправление:
- const chrono::nanoseconds __delta = __atime - __c_entry;
- const __clock_t::time_point __s_atime = __s_entry
+ __delta; + const auto __delta = __atime - __c_entry;
+ const auto __s_atime = __s_entry
+ __delta; in file condition_variable