Карта сайта Kansoftware
НОВОСТИУСЛУГИРЕШЕНИЯКОНТАКТЫ
KANSoftWare

Обработка исключений в 32-битных и 64-битных приложениях на Delphi: различия и их влияние на инструменты просмотра стека

Delphi , Интернет и Сети , Браузер

Вопрос, поднятый пользователем, касается проблемы обработки исключений в 64-битных приложениях на Delphi XE4 в режиме отладки. В частности, пользователь столкнулся с непонятными символами в файле карты (map file), такими как _zn6, _zn11 и другими, которые появляются только в 64-битных проектах. В 32-битных проектах все работает корректно, а в 64-битных проектах в режиме выпуска информация в файле карты становится более понятной, но при этом содержит меньше данных.

Основная причина проблемы

Основная причина заключается в различиях в модели обработки исключений между 32-битными и 64-битными системами. В 32-битных системах обработка исключений основана на стеке, тогда как в 64-битных системах используется модель, основанная на таблицах. Это приводит к тому, что компилятор и линкер должны генерировать таблицы обработки исключений, которые записываются в итоговый исполняемый файл.

Сгенерированные имена

Имена, содержащие $pdata$ и $unwind$, являются результатом работы компилятора при обработке блоков except и finally. Эти имена используются линкером для создания таблиц обработки исключений. Компилятор создает их таким образом, чтобы избежать конфликтов с настоящими именами функций.

Проблема с JCL

Проблема заключается в том, что инструмент JCL не способен правильно интерпретировать эти имена, что приводит к непонятным символам в логах стека. Другие инструменты, такие как madExcept, способны корректно отображать имена функций.

Пример кода

Для иллюстрации разницы между 32-битными и 64-битными приложениями можно рассмотреть следующий пример:

procedure Foo;
begin
end;

procedure Main;
begin
  try
  finally
    Foo;
  end;
end;

begin
  Main;
end.

В 64-битных приложениях блок finally компилируется дважды: один раз для обычной обработки (без исключений) и один раз для обработки исключений. Это приводит к тому, что функция Foo вызывается дважды в стек-трейсе.

Рекомендации

Для решения проблемы с JCL можно рассмотреть возможность обновления инструмента или использования альтернативных средств просмотра стека, которые лучше справляются с обработкой информации о таблицах исключений.

Заключение

Таким образом, проблема, с которой столкнулся пользователь, является следствием различия в обработке исключений между 32-битными и 64-битными системами. Использование таблиц для обработки исключений в 64-битных системах приводит к появлению специфических символов в файлах карт и стековых трассировках, которые могут быть непонятны без специальных инструментов для их интерпретации.

Создано по материалам из источника по ссылке.

Вопрос касается различий в обработке исключений между 32-битными и 64-битными приложениями на Delphi, что влияет на инструменты просмотра стека и приводит к неправильной интерпретации символов в файлах карт.


Комментарии и вопросы

Получайте свежие новости и обновления по Object Pascal, Delphi и Lazarus прямо в свой смартфон. Подпишитесь на наш Telegram-канал delphi_kansoftware и будьте в курсе последних тенденций в разработке под Linux, Windows, Android и iOS




Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.


:: Главная :: Браузер ::


реклама


©KANSoftWare (разработка программного обеспечения, создание программ, создание интерактивных сайтов), 2007
Top.Mail.Ru

Время компиляции файла: 2024-12-22 20:14:06
2025-02-20 22:30:58/0.0034630298614502/0