Boost 测试在使用 Clang 4.1 (LLVM 3.1svn) 退出时崩溃



考虑这个简单的程序:

#include <string>
#include <iostream>
#define BOOST_TEST_DYN_LINK
#define BOOST_TEST_MODULE "MyTest"
#include <boost/test/unit_test.hpp>
using namespace std;
template<char* S>
void Test()
{
    BOOST_REQUIRE("Boom!" != string(S));
}
char bang[] = "Bang!";
BOOST_AUTO_TEST_CASE(Boom)
{
    char boom[] = "Boom!";
    Test<bang>();
}

我使用的是Mac OS X v10.8.2(Mountain Lion),并安装了XCode 4.5。

该程序在使用GCC编译时工作,例如,

gcc test.cpp -lboost_unit_test_framework-mt -lstdc++

但是当使用Apple Clang 4.1(标签/Apple/clang-421.11.65)(基于LLVM 3.1svn)编译时

崩溃
clang -std=c++11 -stdlib=libc++ -lc++ test.cpp -lboost_unit_test_framework-mt

我使用的是使用 BREW 安装的 Boost 1.51.0。使用 Clang 重新编译 Boost 无济于事。

这个谜团有解之谜吗?

./a.out
Running 1 test case...
*** No errors detected
Segmentation fault: 11
gdb ./a.out
GNU gdb 6.3.50-20050815 (Apple version gdb-1822) (Sun Aug  5 03:00:42 UTC 2012)
...
This GDB was configured as "x86_64-apple-darwin"...Reading symbols for shared libraries .... done
(gdb) r
Starting program: /private/tmp/xx/a.out 
Reading symbols for shared libraries +++............................. done
Running 1 test case...
*** No errors detected
Program received signal EXC_BAD_ACCESS, Could not access memory.
Reason: 13 at address: 0x0000000000000000
0x0000000100056c56 in boost::unit_test::test_unit::~test_unit ()
(gdb) where
#0  0x0000000100056c56 in boost::unit_test::test_unit::~test_unit ()
#1  0x000000010002435f in boost::unit_test::master_test_suite_t::~master_test_suite_t ()
#2  0x00000001000244dd in boost::unit_test::framework_impl::~framework_impl ()
#3  0x00007fff96179307 in __cxa_finalize ()
#4  0x00007fff9617af57 in exit ()
#5  0x00007fff944897e8 in start ()
lldb a.out
Current executable set to 'a.out' (x86_64).
(lldb) r
Process 71553 launched: '/private/tmp/xx/a.out' (x86_64)
Running 1 test case...
*** No errors detected
Process 71553 stopped
* thread #1: tid = 0x1c03, 0x0000000100056c56 libboost_unit_test_framework.dylib`boost::unit_test::test_unit::~test_unit() + 86, stop reason = EXC_BAD_ACCESS (code=13, address=0x0)
    frame #0: 0x0000000100056c56 libboost_unit_test_framework.dylib`boost::unit_test::test_unit::~test_unit() + 86
libboost_unit_test_framework.dylib`boost::unit_test::test_unit::~test_unit() + 86:
-> 0x100056c56:  lock   
   0x100056c57:  xaddl  %ecx, -8(%rax)
   0x100056c5b:  testl  %ecx, %ecx
   0x100056c5d:  jg     0x100056c68               ; boost::unit_test::test_unit::~test_unit() + 104
clang --version
Apple clang version 4.1 (tags/Apple/clang-421.11.65) (based on LLVM 3.1svn)
Target: x86_64-apple-darwin12.2.0
Thread model: posix

使用 C++11 选项重新编译 Boost 就可以了。

./bootstrap.sh --with-toolset=clang --prefix=/usr/local
sudo ./b2 install toolset=clang cxxflags="-std=c++11 -stdlib=libc++" linkflags="-stdlib=libc++" threading=multi

我上次只使用./b2 install犯了一个错误,但安装步骤似乎在安装之前构建了一些库。

我遇到了与timlukins相同的问题。我必须做cmake .. -DBoost_USE_STATIC_LIBS=YES.但是,例如,由于我在编译boost_timer时遇到了其他问题,因此我发现我的包含不正确。

我不得不替换:

#include <boost/test/included/unit_test.hpp>

跟:

#include <boost/test/unit_test.hpp>

它在 gcc 和 VS13 上工作正常,但在 clang 上则不行。如果它能帮助...

以下内容似乎有效,但您可能需要其他参数。

USER (~/tmp)
$ clang++ -pedantic test.cpp -lboost_unit_test_framework-mt 
USER (~/tmp)
$ ./a.out 
Running 1 test case...
*** No errors detected

最新更新