Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Начинающим";
Текущий архив: 2006.11.05;
Скачать: [xml.tar.bz2];

Вниз

Delphi + DLL + printf = magic?   Найти похожие ветки 

 
n0name   (2006-10-22 19:30) [0]

Короче обрисую ситуацию.
Есть у меня DLL написанная на чистом Си. Использую в ней вызов printf.
Приложение на Delphi у меня оконное, и поэтому хочу изменить стандартный поток вывода в файл. Вроде всё нормально.

procedure SomeProc();
var
a: array of Integer;
begin

end;

var
hLib: THandle;
GideOpen: function (pszAddress: PChar; dwFlags: DWORD): DWORD; cdecl;
hFile: THandle;

test: DWORD;
br: DWORD;

begin
hFile := CreateFile("res.txt", GENERIC_READ or GENERIC_WRITE, FILE_SHARE_READ, nil, CREATE_ALWAYS, 0, 0);
SetStdHandle(STD_OUTPUT_HANDLE, hFile);
hLib := LoadLibrary("H:\msys\home\n0name\wrapper\wrapper.dll");
@GideOpen := GetProcAddress(hLib, "Open");
GideOpen("test", 2);
FreeLibrary(hLib);
CloseHandle(hFile);
SomeProc();
end.

Если закомментировать var a: array of Integer, то всё работает, то есть printf выводит в файл. Как связано это между собой?


 
guav ©   (2006-10-22 20:40) [1]

Телепатор не работает.
Что происходит если не закомментировать var a: array of Integer ?


 
n0name   (2006-10-22 21:05) [2]


> то всё работает, то есть printf выводит в файл.

Если не закомментировать то не работает, и printf не выводит в файл.


 
guav ©   (2006-10-22 21:18) [3]

a: array of Integer;
это добавляет неявный try..finally
может что-то со стеком не так ?
Если сравнить ESP до и полсе вызова ?
function GetESP: Pointer;
asm
  MOV EAX, ESP;
end;

 P1 := GetESP;
 GideOpen("test", 2);
 P2 := GetESP;
 if P1 <> P2 then
   Windows.Beep(400, 200);



 
n0name   (2006-10-22 22:00) [4]


> может что-то со стеком не так ?

Навряд ли.


 
Eraser ©   (2006-10-23 00:47) [5]

> [0] n0name   (22.10.06 19:30)

обычно подобные ошибки возникают, когда в программе не правильно работают с памятью.
то, что если убрать a: array of Integer; ошибки нету - чистая случайность.


 
n0name   (2006-10-23 06:02) [6]


> Eraser ©   (23.10.06 00:47) [5]

Это полный листинг программы. Где неправильная работа с памятью?



Страницы: 1 вся ветка

Форум: "Начинающим";
Текущий архив: 2006.11.05;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.04 c
2-1161362732
kulkse
2006-10-20 20:45
2006.11.05
Ошибка при запуске программы.


2-1161188335
fog
2006-10-18 20:18
2006.11.05
Печать графики


15-1160414992
Kolan
2006-10-09 21:29
2006.11.05
А что это mail.ru падать вздумал?


15-1161175439
zdm
2006-10-18 16:43
2006.11.05
dinamiv var bds2006


15-1160684515
kolyann..
2006-10-13 00:21
2006.11.05
help!!!





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский