Rambler's Top100
"Knowledge itself is power"
F.Bacon
Поиск | Карта сайта | Помощь | О проекте | ТТХ  
 Круглый стол
  
Правила КС
>> Настройки

Фильтр вопросов
>> Новые вопросы
отслеживать по
>> Новые ответы

Избранное

Страница вопросов
Поиск по КС


Специальные проекты:
>> К л ю к в а
>> Г о л о в о л о м к и

Вопрос №

Задать вопрос
Off-topic вопросы

Помощь

 
 К н и г и
 
Книжная полка
 
 
Библиотека
 
  
  
 


Поиск
 
Поиск по КС
Поиск в статьях
Яndex© + Google©
Поиск книг

 
  
Тематический каталог
Все манускрипты

 
  
Карта VCL
ОШИБКИ
Сообщения системы

 
Форумы
 
Круглый стол
Новые вопросы

 
  
Базарная площадь
Городская площадь

 
   
С Л С

 
Летопись
 
Королевские Хроники
Рыцарский Зал
Глас народа!

 
  
ТТХ
Конкурсы
Королевская клюква

 
Разделы
 
Hello, World!
Лицей

Квинтана

 
  
Сокровищница
Подземелье Магов
Подводные камни
Свитки

 
  
Школа ОБЕРОНА

 
  
Арсенальная башня
Фолианты
Полигон

 
  
Книга Песка
Дальние земли

 
  
АРХИВЫ

 
 

Сейчас на сайте присутствуют:
 
  
 
Во Флориде и в Королевстве сейчас  19:46[Войти] | [Зарегистрироваться]
Ответ на вопрос № 79508

17-04-2011 04:17
Здравствуйте.
Есть приложение, прекрасно работающее на ХР. Но под Вистой/семеркой вылетает при запуске. Поручили мне разобраться в чем проблема. Оказалось, под отладчиком программа запускается и работает! Но стоит только запустить вне отладчика - и крэш. Посоветуйте - как отладить приложение? Как найти причину, или хотя бы предполагаемое место возникновения ошибки?

[+] Добавить в избранные вопросы

Отслеживать ответы на этот вопрос по RSS

Ответы:


Уважаемые авторы вопросов! Большая просьба сообщить о результатах решения проблемы на этой странице.
Иначе, следящие за обсуждением, возможно имеющие аналогичные проблемы, не получают ясного представления об их решении. А авторы ответов не получают обратной связи. Что можно расценивать, как проявление неуважения к отвечающим от автора вопроса.

18-04-2011 07:13 | Комментарий к предыдущим ответам
Моральный_ehjl
Заголовочники для GDI+ мы используем от progdigy, только немного переделанные (ничего кардинального - разные мелочи, например, добавили методы загрузки из "родного" TStream/ресурсов, вместо возвращения кода ошибки заставили генерировать исключения, добавили кое-какие функции типа ColorToGpColor ну и так далее)

18-04-2011 07:01 | Сообщение от автора вопроса
Спасибо огромное всем отвечавшим. В поисках ответа на свой вопрос нашел 1 в 1 такую же ситуацию: http://stackoverflow.com/questions/2612671/gdi-crashes-when-loading-png-from-istream
И действительно, оказалось что это бага нето Висты, нето Дельфи. В реализации TStreamAdapter есть маленький изьян - в TStreamAdapter.Stat не полностью инициализируется структура TStatStg, в частности pwcsName - если был передан флаг STATFLAG_NONAME, там должен быть nil, но в Висте там оказывался мусор (при запуске из среды под дебаггером магическим образом инициализировался в nil), но мало того - Виста пыталась этот мусор както использовать, что вызывало повреждение кучи.
Заплатка:

type
  TStreamAdapter = class(Classes.TStreamAdapter)
  public
    function Stat(out statstg: TStatStg;
      grfStatFlag: Longint): HRESULT; override; stdcall;
  end;

{ TStreamAdapter }

function TStreamAdapter.Stat(out statstg: TStatStg;
  grfStatFlag: Integer): HRESULT;
begin
  Result := inherited Stat(statstg, grfStatFlag);
  if (Result = S_OK) and (grfStatFlag and STATFLAG_NONAME = STATFLAG_NONAME) then
    statstg.pwcsName := nil;
end;

В таком варианте всё работает отлично.

P.S. Не знаю, может есть смысл в подводные камни отправить? Как думаете?

17-04-2011 21:50
to ~AQUARIUS~
Используете Delphi XE со стандартными хидерами GDI+?
Была очень похожая проблема, но с WindowsXP (на Win7 не проверял), на SP3 работало, на SP2 вываливалось AV при загрузке png файла, решил проблему использованием оригинальных хидеров:
http://www.progdigy.com/files/gdiplus.zip

17-04-2011 12:21 | Комментарий к предыдущим ответам
Это не из той серии, когда после установки сервиспака 7-ка вываливалась с экраном смерти, пытаясь загрузить несуществующий png?

17-04-2011 09:53 | Сообщение от автора вопроса
Нашел где зависает - при вызове GdipLoadImageFromStream из gdiplus.dll, на загрузке png-картинки. Теперь бы разобраться - почему не зависает под дебаггером, какое это имеет отношение к ntdll.dll, ну и самое главное - что с этим делать...

17-04-2011 09:25 | Сообщение от автора вопроса
MrShoor
Да, программа многопоточная, но потоки создаются только потом - после нажатия на некоторые кнопки.
А вообще больше данных давайте
С удовольствием - если б были. Месаджбоксы расставлял в первую очередь - первой строкй в .дпр, на создание форм; ни один не сработал, очевидно, зависает где-то на инициализации модулей. Кстати, пытался совсем убрать код, отвечающий за загрузку ресурсов, из initialization - программа запустилась, правда мне непонятно, как это тогда в ХР работало без проблем. Привожу проблемный код:

class procedure TResources.LoadResources;
var
  hLib: HMODULE;
  hIco: HICON;
  res: TResourceStream;
  img: TGPImage;
  g: TGPGraphics;
begin
  if not Assigned(FButtons) then FButtons := TBitmap.Create;
  if not Assigned(FPanels) then FPanels := TBitmap.Create;
  if not Assigned(FShadow) then FShadow := TGPImage.Create;

  if not Assigned(FJpeg) then FJpeg := TIcon.Create;
  if not Assigned(FPng) then FPng := TIcon.Create;
  if not Assigned(FGif) then FGif := TIcon.Create;

  hLib := HInstance; //LoadLibrary(PChar(ExtractFilePath(ParamStr(0)) + sMediasDll));
  if hLib = 0 then Exit;
  try
    hIco := LoadImage(hLib, 'JPEG', IMAGE_ICON, 48, 48, LR_COLOR or LR_COPYFROMRESOURCE);
    FJpeg.Handle := CopyImage(hIco, IMAGE_ICON, 0, 0, LR_COPYDELETEORG);

    hIco := LoadImage(hLib, 'PNG', IMAGE_ICON, 48, 48, LR_COLOR or LR_COPYFROMRESOURCE);
    FPng.Handle := CopyImage(hIco, IMAGE_ICON, 0, 0, LR_COPYDELETEORG);

    hIco := LoadImage(hLib, 'GIF', IMAGE_ICON, 48, 48, LR_COLOR or LR_COPYFROMRESOURCE);
    FGif.Handle := CopyImage(hIco, IMAGE_ICON, 0, 0, LR_COPYDELETEORG);

    FShadow.LoadFromResource(hLib, 'SHADOW', 'PNG');

    FPanels.PixelFormat := pf24bit;
    img := TGPImage.Create;
    try
      img.LoadFromResource(hLib, 'PANELS', 'PNG');
      FPanels.SetSize(img.Width, img.Height);
      g := TGPGraphics.Create(FPanels.Canvas.Handle);
      try
        g.Clear(ColorToGpColor(clPanels));
        g.DrawImage(img, GpRect(0, 0, img.Width, img.Height));
      finally
        FreeAndNil(g);
      end;
    finally
      FreeAndNil(img);
    end;

    res := TResourceStream.Create(hLib, 'LISTBUTTON', 'PNG');
    try
      res.Position := 0;
      FButtons.LoadFromStream(res);
    finally
      FreeAndNil(res);
    end;
  finally
//    FreeLibrary(hLib);
  end;
end;

Если вызов этого метода убрать из инициализации, то программа при запуске выдает AV в ntdll.dll после чего запускается

17-04-2011 08:47
Программа многопоточная? Если нет - то раскидайте мессаджбоксы по коду, и локализуйте место где виснет. А вообще больше данных давайте. Этих данных явно недостаточно чтобы хоть как то подсказать.

17-04-2011 06:28 | Сообщение от автора вопроса
В секции инициализации одного из модулей был код, который загружал длл, доставал из нее некоторые ресурсы и выгружал. Перенес эти ресурсы в .ехе, теперь программа не вылетает, но выснет, загружая процессор на 90-100%. Опять же, при запуске из среды по F9 всё хорошо

17-04-2011 05:38 | Сообщение от автора вопроса
Системное сообщение об ошибке; тип - APPCRASH; модуль с ошибкой - ntdll.dll; штампы времени; всё :-(
При запуске по F9 из среды всё работает - ни исключений, ни тем более крэша

17-04-2011 05:36 | Вопрос к автору: запрос дополнительной информации
Но под Вистой/семеркой вылетает при запуске
Что и сообщений об ошибке никаких?

Добавьте свое cообщение

Вашe имя:  [Войти]
Ваш адрес (e-mail):На Королевстве все адреса защищаются от спам-роботов
контрольный вопрос:
Жили у бабуси два веселых гуся. Один белый, другой КАКОЙ?
в качестве ответа на вопрос или загадку следует давать только одно слово в именительном падеже и именно в такой форме, как оно используется в оригинале.
Надоело отвечать на странные вопросы? Зарегистрируйтесь на сайте.
Тип сообщения:
Текст:
Жирный шрифт  Наклонный шрифт  Подчеркнутый шрифт  Выравнивание по центру  Список  Заголовок  Разделительная линия  Код  Маленький шрифт  Крупный шрифт  Цитирование блока текста  Строчное цитирование
  • вопрос Круглого стола № XXX

  • вопрос № YYY в тесте № XXX Рыцарской Квинтаны

  • сообщение № YYY в теме № XXX Базарной площади
  • обсуждение темы № YYY Базарной площади
  •  
     Правила оформления сообщений на Королевстве

    Страница избранных вопросов Круглого стола.
      
    Время на сайте: GMT минус 5 часов

    Если вы заметили орфографическую ошибку на этой странице, просто выделите ошибку мышью и нажмите Ctrl+Enter.
    Функция может не работать в некоторых версиях броузеров.

    Web hosting for this web site provided by DotNetPark (ASP.NET, SharePoint, MS SQL hosting)  
    Software for IIS, Hyper-V, MS SQL. Tools for Windows server administrators. Server migration utilities  

     
    © При использовании любых материалов «Королевства Delphi» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

    Яндекс цитирования