boost :: regex ведет себя по-разному при отладке и выпуске сборки - PullRequest
2 голосов
/ 08 сентября 2010
boost::regex re("^\\s*([_\\w\\.]+)\\s*=\\s*([^\\s]+)$");
if(re.empty()){
  std::cout<<"How is this possible?"<<std::endl;
}

Эта строка печатается в моих сборках релиза! (Отладочные сборки в порядке) Работа с MSVC 2008 (vc 9.0)

Опции компилятора для DEBUG:

/Od /I "C:\Program Files\boost\boost_1_44_0" /I "C:\gtest-1.5.0\include" /I "include" /I "include\EMP" /I "dependencies\EMP\include" /I "dependencies\APR\apr-1.3.3\include" /I "dependencies\solclient_5.0.0.22\include" /I "dependencies\SS66\include" /D "WIN32" /D "_DEBUG" /D "_CONSOLE" /D "EMP_WIN_X86_32" /D "_iso_stdcpp_" /D "_CRT_SECURE_NO_DEPRECATE" /D "_SECURE_SCL=0" /D "_EMPAPI_STATIC_BUILD" /D "_EMPAPI_STATIC_LINK" /D "_UNICODE" /D "UNICODE" /Gm /EHsc /RTC1 /MDd /fp:fast /Fo"Debug\" /Fd"Debug\vc90.pdb" /W3 /nologo /c /ZI /TP /errorReport:prompt

Опции компилятора для RELEASE:

/O2 /Oi /GL /I "C:\Program Files\boost\boost_1_44_0" /I "C:\gtest-1.5.0\include" /I "include" /I "include\EMP" /I "dependencies\EMP\include" /I "dependencies\APR\apr-1.3.3\include" /I "dependencies\solclient_5.0.0.22\include" /I "dependencies\SS66\include" /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /D "EMP_WIN_X86_32" /D "_iso_stdcpp_" /D "_CRT_SECURE_NO_DEPRECATE" /D "_SECURE_SCL=0" /D "_EMPAPI_STATIC_BUILD" /D "_EMPAPI_STATIC_LINK" /D "_UNICODE" /D "UNICODE" /FD /EHsc /MD /Gy /fp:fast /Fo"Release\" /Fd"Release\vc90.pdb" /W3 /nologo /c /Zi /TP /errorReport:prompt

Параметры компоновщика для DEBUG:

/OUT:"C:\WorkFlow\cpp_client_library\Debug\cpp_client_library.exe" /INCREMENTAL /NOLOGO /LIBPATH:"C:\WorkFlow\cpp_client_library\workflow_client_cpp\dependencies\APR\apr-1.3.3\Release" /LIBPATH:"C:\WorkFlow\cpp_client_library\workflow_client_cpp\dependencies\EMP\lib\win32_vc80" /LIBPATH:"C:\WorkFlow\cpp_client_library\workflow_client_cpp\dependencies\solclient_5.0.0.22\lib" /LIBPATH:"C:\WorkFlow\cpp_client_library\workflow_client_cpp\dependencies\SS66\lib\i86_w32" /LIBPATH:"C:\Program Files\boost\boost_1_44_0\stage\lib" /LIBPATH:"C:\gtest-1.5.0\msvc\gtest\Debug" /MANIFEST /MANIFESTFILE:"Debug\cpp_client_library.exe.intermediate.manifest" /MANIFESTUAC:"level='asInvoker' uiAccess='false'" /DEBUG /PDB:"c:\WorkFlow\cpp_client_library\Debug\cpp_client_library.pdb" /SUBSYSTEM:CONSOLE /DYNAMICBASE /NXCOMPAT /MACHINE:X86 /ERRORREPORT:PROMPT emp.lib libsolclient.lib tipc.lib tutil.lib gtestd.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib

Параметры компоновщика для RELEASE:

/OUT:"C:\WorkFlow\cpp_client_library\Release\cpp_client_library.exe" /INCREMENTAL:NO /NOLOGO /LIBPATH:"C:\WorkFlow\cpp_client_library\workflow_client_cpp\dependencies\APR\apr-1.3.3\Release" /LIBPATH:"C:\WorkFlow\cpp_client_library\workflow_client_cpp\dependencies\EMP\lib\win32_vc80" /LIBPATH:"C:\WorkFlow\cpp_client_library\workflow_client_cpp\dependencies\solclient_5.0.0.22\lib" /LIBPATH:"C:\WorkFlow\cpp_client_library\workflow_client_cpp\dependencies\SS66\lib\i86_w32" /LIBPATH:"C:\Program Files\boost\boost_1_44_0\stage\lib" /LIBPATH:"C:\gtest-1.5.0\msvc\gtest\Release" /MANIFEST /MANIFESTFILE:"Release\cpp_client_library.exe.intermediate.manifest" /MANIFESTUAC:"level='asInvoker' uiAccess='false'" /DEBUG /PDB:"c:\WorkFlow\cpp_client_library\Release\cpp_client_library.pdb" /SUBSYSTEM:CONSOLE /OPT:REF /OPT:ICF /LTCG /DYNAMICBASE /NXCOMPAT /MACHINE:X86 /ERRORREPORT:PROMPT emp.lib libsolclient.lib tipc.lib tutil.lib gtest.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib

1 Ответ

0 голосов
/ 23 сентября 2010

Я перешел на использование Visual Studio 2005, и проблема исчезла, но теперь я получаю исключение в конце приложения:

Необработанное исключение в 0x0042d935 в myApp.exe: 0xC0000005: Место чтения нарушения прав доступа 0xe06d7390.

стек вызовов

kernel32.dll! 7c812afb ()
[Указанные ниже кадры могут быть неправильными и / или отсутствующими, символы не загружены для kernel32.dll]
kernel32.dll! 7c812afb ()
msvcp80.dll! 7c421201 ()
MSVCP80.DLL! 7c42394d ()
msvcp80.dll! 7c423958 ()
msvcr80.dll! 78158e89 ()
myApp.exe! std :: _ Дерево, std :: allocator>, std :: less, std :: allocator, std :: allocator>>>, 0>> :: erase (std :: _ Tree, std :: allocator> , std :: less, std :: allocator, std :: allocator>>>, 0>> :: iterator _Where = {...}) Строка 759
msvcr80.dll! 78134c39 ()
myApp.exe! std :: _ Дерево, std :: allocator>, std :: less, std :: allocator, std :: allocator>>>, 0>> :: erase (std :: _ Tree, std :: allocator> , std :: less, std :: allocator, std :: allocator>>>, 0>> :: iterator _First = {...}, std :: _ Tree, std :: allocator>, std :: less, std :: allocator, std :: allocator>>>, 0>> :: iterator _Last = {...}) Строка 926 + 0x4f байт myApp.exe! boost :: re_detail :: w32_regex_traits_implementation :: ~ w32_regex_traits_implementation () + 0xc0 байт
myApp.exe! boost :: detail :: sp_counting_impl_p> :: dispose () + 0xf байт
myApp.exe! std :: list const>, длинное const без знака *>, std :: allocator const>, длинное const без знака *>>> :: clear () + 0x3e байт myApp.exe! boost :: object_cache> :: data :: ~ data () + 0x6b байт msvcr80.dll! 781319d8 ()
MSVCR80.DLL! 78131a4b ()
myApp.exe! __tmainCRTStartup () Строка 603 kernel32.dll! 7c817077 ()

...