Приложение хочет разобрать строковое уравнение в математике и вернуть данные пользователю.для этой цели используется библиотека exprtk
для простоты анализа. Я предоставил минимальный рабочий код минимальный рабочий код
, когда приложение анализирует строкукодировать спина к спине [ многопоточный, но заблокированный ]
void reset()
{
// Why? because msvc doesn't support swap properly.
//stack_ = std::stack<std::pair<char,std::size_t> >();
/**
it was crashing on destructor on ~deque()
stating memory reallocation
so I change it to pop so for now this has been resolved
*/
while(stack_.size()) stack_.pop();
state_ = true;
error_token_.clear();
}
теперь код всегда падает на
static inline void destroy(control_block*& cntrl_blck)
{
if (cntrl_blck)
{
/**now crashes on this condition check*/
if ( (0 != cntrl_blck->ref_count) && (0 == --cntrl_blck->ref_count) )
{
delete cntrl_blck;
}
cntrl_blck = 0;
}
}
ОБНОВЛЕНИЕ код вставки обновлен новый код с основным добавлен основной и минимальный рабочий код.все shared_ptr
было удалено.теперь они нормальные объекты.как для функции сброса exprtk, была изменена на исходную
void reset()
{
// Why? because msvc doesn't support swap properly.
stack_ = std::stack<std::pair<char,std::size_t> >();
state_ = true;
error_token_.clear();
}
и добавлена обратная трассировка GDB обратная трасса