2013-08-17 2 views
2

Я скопировал программу из https://github.com/boostorg/log/blob/master/example/basic_usage/main.cpp. Я переименовал main.cpp в mylog.cpp. при запуске я скомпилировал его с -std = C++ 0x (подробности показаны ниже). он был построен отлично, но получил ошибку сегментации, когда я запускаю исполняемый файл. без -std = C++ 0x, программа работает нормально. помогите. Я действительно новичок в C++, поэтому я могу пропустить некоторую отладочную информацию. сообщите мне, есть ли какая-либо информация, необходимая для отладки этой проблемы. БлагодаряC++ -std = C++ 0x вызывают деградацию сегментации (буксировка)

примечание: я раскомментировал первые три строки на этом main.cpp

#define BOOST_LOG_USE_CHAR 
#define BOOST_ALL_DYN_LINK 1 
#define BOOST_LOG_DYN_LINK 1 

параметров сборки из затмения (для того, чтобы построить эту программу, я думаю, что необходима библиотека журнала форсированные):

make all 
Building file: ../mylog.cpp 
Invoking: GCC C++ Compiler 
g++ -I/home/help/usr/local/boost_1_54_0 -O0 -g3 -Wall -c -fmessage-length=0 -std=c++0x -MMD -MP -MF"mylog.d" -MT"mylog.d" -o "mylog.o" "../mylog.cpp" 
Finished building: ../mylog.cpp 

Building target: test 
Invoking: GCC C++ Linker 
g++ -L/home/help/usr/local/lib -o "test" ./mylog.o -lpthread -lboost_thread -lboost_system -lboost_log_setup -lboost_log 
Finished building target: test 

после сборки, я запускаю эту программу и получил ошибку сегментации.

$ ./mylog 
Segmentation fault (core dumped) 

использование gdb. он указывает мне на библиотеку

Program received signal SIGSEGV, Segmentation fault. 
0x00007ffff7100c0a in boost::log::v2_mt_posix::attribute_value_set::find(boost::log::v2_mt_posix::attribute_name) const() from /home/fcai/usr/local/lib/libboost_log.so.1.54.0 
(gdb) list 
73  return strm; 
74 } 
75 
76 int main(int argc, char* argv[]) 
77 { 
78  // This is a simple tutorial/example of Boost.Log usage 
79 
80  // The first thing we have to do to get using the library is 
81  // to set up the logging sinks - i.e. where the logs will be written to. 
82  logging::add_console_log(std::clog, keywords::format = "%TimeStamp%: %Message%"); 
(gdb) bt 
#0 0x00007ffff7100c0a in boost::log::v2_mt_posix::attribute_value_set::find(boost::log::v2_mt_posix::attribute_name) const() from /home/fcai/usr/local/lib/libboost_log.so.1.54.0 
#1 0x000000000042713f in boost::log::v2_mt_posix::value_extractor<boost::mpl::vector2<std::string, std::basic_string<wchar_t, std::char_traits<wchar_t>, std::allocator<wchar_t> > >, boost::log::v2_mt_posix::fallback_to_none, boost::log::v2_mt_posix::expressions::tag::message>::operator() (this=0x7fffffffc6b0, name=..., attrs=...) at /home/fcai/usr/local/boost_1_54_0/boost/log/attributes/value_extraction.hpp:232 
#2 0x00007ffff74c379d in boost::log::v2_mt_posix::aux::light_function<void (boost::log::v2_mt_posix::record_view const&, boost::log::v2_mt_posix::basic_formatting_ostream<char, std::char_traits<char>, std::allocator<char> >&)>::impl<boost::log::v2_mt_posix::(anonymous namespace)::chained_formatter<char, boost::phoenix::actor<boost::proto::exprns_::expr<boost::proto::tagns_::tag::shift_left, boost::proto::argsns_::list2<boost::phoenix::actor<boost::proto::exprns_::basic_expr<boost::proto::tagns_::tag::terminal, boost::proto::argsns_::term<boost::phoenix::argument<2> >, 0l> >, boost::log::v2_mt_posix::expressions::attribute_actor<boost::mpl::vector2<std::string, std::basic_string<wchar_t, std::char_traits<wchar_t>, std::allocator<wchar_t> > >, boost::log::v2_mt_posix::fallback_to_none, boost::log::v2_mt_posix::expressions::tag::message, boost::phoenix::actor> >, 2l> > > >::invoke_impl(boost::log::v2_mt_posix::aux::light_function<void (boost::log::v2_mt_posix::record_view const&, boost::log::v2_mt_posix::basic_formatting_ostream<char, std::char_traits<char>, std::allocator<char> >&)>::impl_base*, boost::log::v2_mt_posix::record_view const&, boost::log::v2_mt_posix::basic_formatting_ostream<char, std::char_traits<char>, std::allocator<char> >&)() from /home/fcai/usr/local/lib/libboost_log_setup.so.1.54.0 
#3 0x0000000000431b64 in boost::log::v2_mt_posix::aux::light_function<void (boost::log::v2_mt_posix::record_view const&, boost::log::v2_mt_posix::basic_formatting_ostream<char, std::char_traits<char>, std::allocator<char> >&)>::operator()(boost::log::v2_mt_posix::record_view const&, boost::log::v2_mt_posix::basic_formatting_ostream<char, std::char_traits<char>, std::allocator<char> >&) const (this=0x652ab8, 
    args#0=..., args#1=...) at /home/fcai/usr/local/boost_1_54_0/boost/log/detail/light_function.hpp:444 
#4 0x00000000004306db in boost::log::v2_mt_posix::basic_formatter<char>::operator() (this=0x652ab8, rec=..., strm=...) at /home/fcai/usr/local/boost_1_54_0/boost/log/expressions/formatter.hpp:157 
#5 0x0000000000430806 in boost::log::v2_mt_posix::sinks::basic_formatting_sink_frontend<char>::feed_record<boost::log::v2_mt_posix::aux::fake_mutex, boost::log::v2_mt_posix::sinks::basic_text_ostream_backend<char> > (this=0x6507c0, rec=..., backend_mutex=..., backend=...) at /home/fcai/usr/local/boost_1_54_0/boost/log/sinks/basic_sink_frontend.hpp:440 
#6 0x000000000042f505 in boost::log::v2_mt_posix::sinks::basic_formatting_sink_frontend<char>::try_feed_record<boost::mutex, boost::log::v2_mt_posix::sinks::basic_text_ostream_backend<char> > (this=0x6507c0, 
    rec=..., backend_mutex=..., backend=...) at /home/fcai/usr/local/boost_1_54_0/boost/log/sinks/basic_sink_frontend.hpp:489 
#7 0x000000000042d28e in boost::log::v2_mt_posix::sinks::synchronous_sink<boost::log::v2_mt_posix::sinks::basic_text_ostream_backend<char> >::try_consume (this=0x6507c0, rec=...) 
    at /home/fcai/usr/local/boost_1_54_0/boost/log/sinks/sync_frontend.hpp:145 
#8 0x00007ffff7106053 in boost::log::v2_mt_posix::core::push_record_move(boost::log::v2_mt_posix::record&)() from /home/fcai/usr/local/lib/libboost_log.so.1.54.0 
#9 0x000000000041f8f1 in push_record (rec=..., this=0x651050) at /home/fcai/usr/local/boost_1_54_0/boost/log/core/core.hpp:308 
#10 boost::log::v2_mt_posix::sources::basic_logger<char, boost::log::v2_mt_posix::sources::logger, boost::log::v2_mt_posix::sources::single_thread_model>::push_record_unlocked(boost::log::v2_mt_posix::record&&) (this=0x7fffffffccc0, rec=...) at /home/fcai/usr/local/boost_1_54_0/boost/log/sources/basic_logger.hpp:268 
#11 0x000000000041d2e6 in boost::log::v2_mt_posix::sources::basic_composite_logger<char, boost::log::v2_mt_posix::sources::logger, boost::log::v2_mt_posix::sources::single_thread_model, boost::log::v2_mt_posix::sources::features<> >::push_record(boost::log::v2_mt_posix::record&&) (this=0x7fffffffccc0, rec=...) at /home/fcai/usr/local/boost_1_54_0/boost/log/sources/basic_logger.hpp:582 
#12 0x000000000041a9b4 in boost::log::v2_mt_posix::aux::record_pump<boost::log::v2_mt_posix::sources::logger>::~record_pump (this=0x7fffffffd170, __in_chrg=<optimized out>) 
    at /home/fcai/usr/local/boost_1_54_0/boost/log/sources/record_ostream.hpp:279 
#13 0x0000000000414de3 in main (argc=1, argv=0x7fffffffd7b8) at ../mylog.cpp:116 
(gdb) 
+0

дайте мне знать, если я могу предоставить дополнительную информацию. спасибо – cppython

+0

Содержимое 'mylog.cpp' будет значительно аддитивным для поиска вашей проблемы. Если это так, как я полагаю, это программа, в ней есть неопределенное поведение, и поэтому результаты тоже будут. Вы новичок в C++, и я не могу себе представить, что это слишком большой код-список. Обновите свой вопрос блоком кода, содержащим этот файл (и любые соответствующие пользовательские заголовки). – WhozCraig

+0

mylog.cpp размещен на компоновщике: https://github.com/boostorg/log/blob/master/example/basic_usage/main.cpp извините, я изменил имя main.cpp на mylog.cpp – cppython

ответ

0

У меня была такая же проблема. Так или иначе, когда я удаляю% Message% из следующей строки, это работает как минимум. Однако, очевидно, теперь журнал не появляется на консоли.

logging::add_console_log(std::clog, keywords::format = "%TimeStamp%: %Message%"); 

Измените его на следующее: вы увидите результаты, как ожидалось.

logging::add_console_log(std::clog, keywords::format = expr::stream 
     << expr::format_date_time<boost::posix_time::ptime>("TimeStamp", "%Y-%m-%d, %H:%M:%S.%f") 
     << " --> " << expr::message);