2

我正在使用 boost 1.53.0,到目前为止没有任何问题(并且使用了套接字、计时器、容器、算法,所有这些都没有麻烦)。

我喜欢使用 boost 异常的想法,尤其是因为行号和其他原因。

但是,在我的(超级简单的)代码中:

#include <iostream>
#include <fstream>

#include <boost/scoped_ptr.hpp>
#include <boost/exception/all.hpp>

struct my_error: virtual boost::exception, virtual std::exception { };

int main(int argc, char* argv[])
{
  try
  {
    BOOST_THROW_EXCEPTION(my_error());
  }
  catch(...)
  {
    std::cout <<"fail";
  }
}

使用 CMAKE 生成的项目(希望这不会搞砸)

cmake_minimum_required (VERSION 2.8)
project(error_test)
IF(WIN32)
   set(Boost_USE_STATIC_LIBS ON)
   set(Boost_USE_MULTITHREADED ON) 
   set(Boost_USE_STATIC_RUNTIME OFF)
   set(Boost_NO_SYSTEM_PATHS FALSE)
ENDIF()

find_package(Boost COMPONENTS system date_time)
include_directories(${Boost_INCLUDE_DIRS}
    )



add_executable(${PROJECT_NAME} main.cpp)

target_link_libraries(${PROJECT_NAME}
${Boost_LIBRARIES})

BOOST_THROW_EXCEPTION 不是抛出,而是进入无限递归!

编译器甚至捕捉到了这一点,并发出编译器警告

警告 C4717:'boost::exception_detail::throw_exception_':在所有控制路径上递归,函数将导致运行时堆栈溢出。

它只是不断打击:

test.exe!boost::exception_detail::throw_exception_<my_error>(const my_error & x, const char * current_function, const char * file, int line)  Line 84 + 0xd1 bytes  C++

我正在使用visual studio 2010(win 64)。如果有帮助,我使用以下命令构建了 boost:

.\b2 install --prefix=C:\devtools\boost_1_53_0 --toolset=msvc --build-type=complete --build-dir=C:\devtools\bin\boost_1_53_0 address-model=64 architecture=x86

编辑添加扩展宏:

看起来宏扩展为

 ::boost::exception_detail::throw_exception_(my_error(), __FUNCSIG__  ,"main.cpp",40);

扩展到

 throw_exception_( E const & x, char const * current_function, char const * file, int line )
 {
     ::boost::exception_detail::throw_exception_(set_info( set_info( set_info( enable_error_info(x), throw_function(current_function)), throw_file(file)), throw_line(line)), __FUNCSIG__  ,"C:\\devtools\\boost_1_53_0\\boost/throw_exception.hpp",91);

#line 92 "C:\devtools\boost_1_53_0\boost/throw_exception.hpp" }

4

2 回答 2

3

这简直太奇怪了。您可以在https://svn.boost.org/svn/boost/tags/release/Boost_1_53_0/boost/throw_exception.hpp轻松查看boost::exception::throw_exception_ 根本不是递归的。

我能看到这种事情发生的唯一方法是使用邪恶的宏。请尝试将其放在您的主文件中,在每个包含指令之前和之后。

#if defined(throw_exception) || defined(throw_exception_)
#error Somebody set us up the bomb
#endif
于 2013-06-22T14:21:43.660 回答
0

好的,所以看起来出于某种原因

    throw_exception_( E const & x, char const * current_function, char const * file, int line )
    {
        boost::throw_exception(
            set_info(
                set_info(
                    set_info(
                        enable_error_info(x),
                        throw_function(current_function)),
                    throw_file(file)),
                throw_line(line)));
    }

改为

    throw_exception_( E const & x, char const * current_function, char const * file, int line )
    {
        BOOST_THROW_EXCEPTION(
            set_info(
                set_info(
                    set_info(
                        enable_error_info(x),
                        throw_function(current_function)),
                    throw_file(file)),
                throw_line(line)));
    }

在我的代码中......所以我必须打破我自己的提升构建。对不起,大雁追逐!我投票关闭了这个帖子......

于 2013-06-22T14:57:55.597 回答