![]() |
Модераторы: bsa |
![]() ![]() ![]() |
|
malor |
|
|||
Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 632 Регистрация: 17.11.2006 Репутация: нет Всего: нет |
![]() По CallStack'у уходящему длинной вереницей серых строк вниз не ясно на каком месте кода возникло. Как вычислить расположение? |
|||
|
||||
asmdzen |
|
|||
![]() ![]() ![]() Профиль Группа: Участник Сообщений: 345 Регистрация: 28.11.2010 Репутация: 3 Всего: 5 |
не исключено что здесь просто испорчен стек и ничего полезного узнать не удастся.
|
|||
|
||||
xvr |
|
|||
Эксперт ![]() ![]() ![]() ![]() Профиль Группа: Комодератор Сообщений: 7046 Регистрация: 28.8.2007 Где: Дублин, Ирландия Репутация: 35 Всего: 223 |
Похоже ваш SnapShotSrv.exe был собран без отладочной информации. Проверьте, вы Debug конфигурацию запускаете?
|
|||
|
||||
Estranged |
|
|||
Бывалый ![]() Профиль Группа: Участник Сообщений: 158 Регистрация: 30.8.2010 Репутация: нет Всего: 3 |
как узнать место, возникновения ошибки - даже адрес где упало написан: 0x30303131. Подключаем Windbg и смотрим. Или собрать модуль с отладочной информацией, тогда еще удобнее будет смотреть.
|
|||
|
||||
bsa |
|
|||
![]() Эксперт ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 9185 Регистрация: 6.4.2006 Где: Москва, Россия Репутация: 85 Всего: 196 |
Estranged, тебе адрес подозрительным не кажется? по мне так смахивает на текст "1100".
|
|||
|
||||
Estranged |
|
|||
Бывалый ![]() Профиль Группа: Участник Сообщений: 158 Регистрация: 30.8.2010 Репутация: нет Всего: 3 |
bsa, еще какой подозрительный. Смотреть по стеку вызовов, откуда пришли, кто сделал передачу управления по такому адресу. Отладчик VS не умеет показывать имена функций, т.к. не имеет правильной pdb, а правильно настроенный Windbg сам скачает нужную pdb для ntdll и всех задействованных dll, что, как я уже писал, существенно облегчит диагностику.
|
|||
|
||||
xvr |
|
|||
Эксперт ![]() ![]() ![]() ![]() Профиль Группа: Комодератор Сообщений: 7046 Регистрация: 28.8.2007 Где: Дублин, Ирландия Репутация: 35 Всего: 223 |
Судя по стеку вызовов в какую то WinAPI функцию в качестве callback'а вместо адреса процедуры передали строку
|
|||
|
||||
malor |
|
||||
Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 632 Регистрация: 17.11.2006 Репутация: нет Всего: нет |
Вот этот код закомментил и перестало падать:
Что в нем неправильно? Какой-нибудь выход за границы? Собственно функция логгирования:
Это сообщение отредактировал(а) malor - 28.7.2011, 20:13 |
||||
|
|||||
Dem_max |
|
|||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1780 Регистрация: 12.4.2007 Репутация: 4 Всего: 39 |
может не жопиться ? и сделать так
-------------------- Американские программисты долго не могли понять, почему русские при зависании Windоws всё время повторяют "Твой зайка написал" ("Yоur bunnу wrоte") |
|||
|
||||
Estranged |
|
|||
Бывалый ![]() Профиль Группа: Участник Сообщений: 158 Регистрация: 30.8.2010 Репутация: нет Всего: 3 |
Переполнение буфера на 99%.
_itoa(keyCode, strKeyCode, 10); - пусть 1 символ + нуль-терминатор _itoa(down, strDown, 2); strcat(strKeyCode, " "); - +1 символ strcat(strKeyCode, strDown); - пусть еще +1 strMesg = strcat(asctime, strMesg); - ? strMesg = strcat(strMesg, "\n"); +1 Итого уже заняты 5 символов, asctime возвращает строку значительно длиннее 5 символов, в итоге стек подпорчен. |
|||
|
||||
bsa |
|
|||
![]() Эксперт ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 9185 Регистрация: 6.4.2006 Где: Москва, Россия Репутация: 85 Всего: 196 |
malor, Estranged, быстро бежать и смотреть описание _itoa(). Ошибку найдете сразу же!!!
|
|||
|
||||
Estranged |
|
|||
Бывалый ![]() Профиль Группа: Участник Сообщений: 158 Регистрация: 30.8.2010 Репутация: нет Всего: 3 |
bsa, и что же там такого написано, что было упущено?
|
|||
|
||||
Dem_max |
|
|||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1780 Регистрация: 12.4.2007 Репутация: 4 Всего: 39 |
да и что же там не то, я тоже не в курсе
-------------------- Американские программисты долго не могли понять, почему русские при зависании Windоws всё время повторяют "Твой зайка написал" ("Yоur bunnу wrоte") |
|||
|
||||
asmdzen |
|
|||
![]() ![]() ![]() Профиль Группа: Участник Сообщений: 345 Регистрация: 28.11.2010 Репутация: 3 Всего: 5 |
Estranged, Dem_max, последний параметр не ограничение по символам а основание системы счисления (base), там по любому будет переполнение буфера
http://www.cplusplus.com/reference/clibrary/cstdlib/itoa/ |
|||
|
||||
Dem_max |
|
|||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1780 Регистрация: 12.4.2007 Репутация: 4 Всего: 39 |
ну и так понятно, что это код системы счисления, но как раз в этом месте ошибки нету.
-------------------- Американские программисты долго не могли понять, почему русские при зависании Windоws всё время повторяют "Твой зайка написал" ("Yоur bunnу wrоte") |
|||
|
||||
![]() ![]() ![]() |
Правила форума "C/C++: Для новичков" | |
|
Запрещается! 1. Публиковать ссылки на вскрытые компоненты 2. Обсуждать взлом компонентов и делиться вскрытыми компонентами
Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, JackYF, bsa. |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | C/C++: Для новичков | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |