Форум программистов, компьютерный форум, киберфорум
Visual C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 15.01.2010
Сообщений: 109

window subclassing: зацикливание

21.08.2010, 17:58. Показов 1011. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
У меня есть программа написанная на MS VC++ 6. В ней для ряда окон control-ов выполняется subclassing (эт было нужно для собственного механизма skin-ов). Новая window procedure в коце своей работы вызывает старую (адрес старой был сохранён при выполнении subclassing-а) — через CallWindowProc, разумеется.

Всё шло хорошо пока один из клиентов (WinXP) не пожаловался что программа падает сразу при запуске. Когда я снял crash dump оказалось: произошло переполнение стека. Примерно вот так:

user32.dll!__SEH_prolog() + 0x1b bytes
user32.dll!_CallWindowProcAorW@24() + 0x51 bytes
user32.dll!_CallWindowProcW@20() + 0x1b bytes
MyModule.dll!CSkinManager::SkinWindowPro c(HWND__ * hWnd=0x00150526, unsigned int mess=70, unsigned int wParam=0, long lParam=1230632) Line 7120 C++
user32.dll!_InternalCallWinProc@20() + 0x28 bytes
user32.dll!_UserCallWinProcCheckWow@32() + 0xb7 bytes
user32.dll!_CallWindowProcAorW@24() + 0x51 bytes
user32.dll!_CallWindowProcW@20() + 0x1b bytes
02ef007c()
user32.dll!_InternalCallWinProc@20() + 0x28 bytes
user32.dll!_UserCallWinProcCheckWow@32() + 0xb7 bytes
user32.dll!_CallWindowProcAorW@24() + 0x51 bytes
user32.dll!_CallWindowProcW@20() + 0x1b bytes
MyModule.dll!CSkinManager::SkinWindowPro c(HWND__ * hWnd=0x00150526, unsigned int mess=70, unsigned int wParam=0, long lParam=1230632) Line 7120 C++
user32.dll!_InternalCallWinProc@20() + 0x28 bytes
user32.dll!_UserCallWinProcCheckWow@32() + 0xb7 bytes
user32.dll!_CallWindowProcAorW@24() + 0x51 bytes
user32.dll!_CallWindowProcW@20() + 0x1b bytes
02ef007c()
....
user32.dll!_InternalCallWinProc@20() + 0x28 bytes
user32.dll!_UserCallWinProcCheckWow@32() + 0xb7 bytes
user32.dll!_CallWindowProcAorW@24() + 0x51 bytes
user32.dll!_CallWindowProcW@20() + 0x1b bytes
MyModule.dll!CSkinManager::SkinWindowPro c(HWND__ * hWnd=0x00150526, unsigned int mess=70, unsigned int wParam=0, long lParam=1230632) Line 7120 C++
user32.dll!_InternalCallWinProc@20() + 0x28 bytes
user32.dll!_UserCallWinProcCheckWow@32() + 0xb7 bytes
user32.dll!_CallWindowProcAorW@24() + 0x51 bytes
user32.dll!_CallWindowProcW@20() + 0x1b bytes
02ef007c()
user32.dll!_InternalCallWinProc@20() + 0x28 bytes

Где MyModule.dll — имя моей DLL-ки в моей порграмме; CSkinManager::SkinWindowProc — имя той самой моей оконной процедуры, которую я использовал в subclassing-е. Что такое '02ef007c()' — я не смог выяснить. WinDbg вместо него показывает '<Unloaded_RT40.dll>+0x02ef007b', что мне тоже ничего не говорит. По crash dump-у я увидел что в мой порцесс внедрились несколько чужих DLL-ей, например AME_SMTPSensor.dll от какой-то программы Digital Guard (что-то вроде антивируса). Или penjpn.dll от 'Microsoft JPN Handwriting Input UI' (клиент находитяс в Японии). И ещё несколько. Возможно, '02ef007c()' как раз указывает на код такой внедрённой DLL-ки?

Так или иначе, поризошло зацикливание оконных процедур. Моя оконнная процедура CSkinManager::SkinWindowProc в конце работы вызывает CallWindowProc для старой (предшествующей) оконной процедуры. Эта старая, расположенная в том самом таинственном '02ef007c()', в конце концов вызывает мою же CSkinManager::SkinWindowProc. Через какое-то время стек переполняется и пргорамма падает.

Моя версия: какая-то из внедрённых DLL-ек перехватила оконную порцедуру моего окна как только то было создано. Потом, чуть позже, его перехватил я (у меня этот перехват происходит не сразу после создания окна — по некоторым причинам). При этом я сохранил адрес прежней оконной процедуры. Сразу после этого внедрённая DLL-ка обнаружила этот факт и ОПЯТЬ перехватила оконную процедуру на себя — очевидно она всегда хочет быть наверху. При этом её оконная процедура, подобно моей, сохранила адрес прежней оконной порцедуры (моей); и вызывает её в конце работы. Получается зацикливание.

Какие есть идеи — что можно сделать? Я не имею доступа к тому компьютеру и даже н знаю какая именно из внедрённых DLL-ек виновата.
Glen
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.08.2010, 17:58
Ответы с готовыми решениями:

Загвоздка с Subclassing в RichEdit
Доброго времени суток! Столкнулся со следующей проблемой - Subclassing в RichEdit. Класс CColoredRichTextBox: class...

Крах Access при Subclassing
Помогите, пожалуйста, разобраться, уже голову сломал: Мне надо управлять приложением Access 2007 при помощи внешней программы. Написал...

SendMessage в обход Subclassing'а
Столкнулся с проблемкой. Есть корявая корпоративная бд с убогим интерфейсом. Нужно фильтровать в SysTreeView32 элементы. Написал код на VBA...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.08.2010, 17:58
Помогаю со студенческими работами здесь

Вызов Window.ShowDialog() срабатывает как Window.Show(), т.е. я могу нажимать на другие окна
Здравствуйте, уважаемые форумчане. Столкнулся с проблемой. У меня есть окно, которое выполняет некоторые действия всё время работы...

Window является свойством глобального объекта Window
если объект window является свойством глобального объекта Window, то почему запись: Window.window // =&gt; undefined

Почему в Opera v12.0 координаты окна браузера относительно экрана window.screenX или window.screenY выдает 0?
Здравствуйте, подскажите пожалуйста почему в Opera v 12.0, координаты окна браузера относительно экрана - window.screenX или...

DICOM + Window Center + Window Width
Всем добрый день! Разбираюсь с файлами DICOM. в частности рентгеновскими снимками. Кто-нибудь может объяснить смысл тега 0028 3002, нашел...

window.document.write и window.alert()
1)Вот смотрите, window ч точки зрения языка джаваскрипт - это объект, скажите это объект какого класса?Ведь говорят что window это самый...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru