Russian Qt Forum

Qt => Установка, сборка, отладка, тестирование => Тема начата: Clever от Июль 10, 2014, 19:50



Название: Программа неожиданно завершилась
Отправлено: Clever от Июль 10, 2014, 19:50
Доброго все дня или вечера. Приложение создается в Qt  Creator, в самой программе существует длительный цикл обработки. Предполагается что этот цикл будит жить бесконечно долго. В ходе работы этого цикла программа падает и в дебагере появляется сообщение "Программа неожиданно завершилась."
Подскажите как отследить строку где программа падает.
qDebug() не надо предлагать, поскольку цикл может работать сутки , а лишь потом упасть...
Меня интересует именно процесс отладки.

Вот допустим при разработке на C# при возникновении исключения Visual Studio сразу показывает на какой строке остановилась программа.

возможно ли подобное в Qt Creator, с компилятором MinGW ?. если да то подскажите чайнику =)


Название: Re: Программа неожиданно завершилась
Отправлено: gil9red от Июль 10, 2014, 20:02
Меняете сборку на "Debug" и запускаете с ней (Кнопка с зеленым треугольником).
Более глубокий вариант: Меняете сборку на "Debug" и запускаете с отладчиком (Кнопка с зеленым треугольником и с жуком).
Ставите в коде вызовы в консоль (например, qDebug()) и смотрите до какого вызова не дошло.

При втором варианте, появится дополнительные панели для отладки, дольше будет запускаться приложение, но при падении программы, покажет стек вызовов функции и место в коде, в котором и произошла ошибка.


Название: Re: Программа неожиданно завершилась
Отправлено: Clever от Июль 10, 2014, 20:10
Да, кстати забыл упомянуть и об этом. Дело в том, что такой вариант тоже пробовал, под отладкой и под "Debug" программа запускается, но... У приложении предусмотрена работа с несколькими потоками, те цикли вычислений находятся в каждом потоке по одному циклу.... Приложение использует библиотеку OpenCV и в потоке обрабатывает изображение с камер...
Так вот когда запускаю поток по кнопке то выдается сообщение отладчиком "Приложение остановлено т.к. оно получило сигнал от операционной системы". Если я запускаю приложение под "Debug" но без отладки такого сообщения нет, потоки работают... Но время от времени падают =(