В C ++ при работе с библиотекой C, которая использует Longjmp для обработки ошибок. Безопасно ли, чтобы C -код прыгнул в C ++ с помощью setjmp . Я знаю, что отпрыгнуть от кода C ++ может привести к тому, что проблемы с деструкторами не называются, но это то же самое для прыжка в код C ++. < /P>
Псевдо -код использования < /p>
Код: Выделить всё
if( setjmp( lib_get_jmpbuf() ) )
{
throw "exception";
}
if( lib_question() )
{
std::vector stuff(5);
lib_could_jump_way(stuff.data(), stuff.size());
}
Если это не безопасно, как вы безопасно взаимодействуете с такими библиотеками C?
Подробнее здесь:
https://stackoverflow.com/questions/796 ... -code-safe