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

Вниз

GetProcAddress   Найти похожие ветки 

 
френк   (2005-09-21 22:18) [0]

Указатель на функцию DLL, который возвращает GetProcAddress является постоянным для конкретной DLL? или он может измениться после освобождения модуля и при повторной его загрузке?

Знаю, что туплю, наверняка. Но прошу вас - поясните.


 
Anton_K ©   (2005-09-21 22:22) [1]

Может измениться.


 
френк   (2005-09-21 22:26) [2]

спасибо, вы меня уверили )


 
evvcom ©   (2005-09-22 09:24) [3]

После FreeLibrary может произойти Load другой Library по тем же адресам и последующий Load интересующей Library загрузит ее уже по другим адресам. Отсюда и смена адреса.


 
френк   (2005-09-23 13:38) [4]

но если не было другого LoadLibrary ? требуется ли все-таки рефрешить указатели, если небыло других вызовов ? простите, возможно, я зря так привезался с этим )


 
isasa ©   (2005-09-23 13:41) [5]

Если указатель нужен, зачем выгружать DLL ????


 
evvcom ©   (2005-09-23 13:55) [6]


> требуется ли все-таки рефрешить указатели, если небыло других
> вызовов

Откуда ты знаешь были или нет другие вызовы? Если ты ничего не подгружаешь, это еще не значит, что и система ничего не подгружает. Кроме того, имеется куча программ, которые вешают глобальные хуки и внедряют в адресные пространства чужих процессов свои dll. Ты об этом можешь даже не догадываться, но это факт. Поэтому, если тебя не раздражают сообщения Access Violation, то можешь и не рефрешить указатели.


 
evvcom ©   (2005-09-23 13:56) [7]

а лучше ответь на [5]


 
begin...end ©   (2005-09-23 14:15) [8]

> френк   (21.09.05 22:18)

> Указатель на функцию DLL, который возвращает GetProcAddress
> является постоянным для конкретной DLL? или он может измениться
> после освобождения модуля и при повторной его загрузке?

В общем случае -- может измениться. В частном случае -- когда DLL скомпонована с указанием нужного базового адреса загрузки и запретом загрузки по альтернативным адресам -- не может измениться, но при этом вполне вероятна ситуация, когда DLL не загрузится совсем, т.к. нужная область АП процесса может быть уже занята.


 
френк   (2005-09-23 21:19) [9]

теперь все понятно. спасибо всем.

относительно [5] - спросил просто из спортивного интереса )


 
Poirot ©   (2005-09-24 15:36) [10]

Скажу по секрету страшную тайну - адрес абсолютный может, а вот относительный нет:)
А базовый адрес относительно которого переводятся относительные в абсолютные он есть как раз HMODULE который возвращает таки LoadLibrary :) Вот вам и ответ:)
Полагаясь на то, что поведение загрузчика не отличается разнообразием то что можно таки и не вызывать повторно GetProcAddress ^)



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

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

Наверх




Память: 0.46 MB
Время: 0.07 c
14-1127549337
DiamondShark
2005-09-24 12:08
2005.10.16
Посоветуйте ньюс-сервер для чтения конференций relcom.


3-1125926607
AndrewK
2005-09-05 17:23
2005.10.16
Хранение справочников в одной таблице. Предлагаю обсудить идею.


3-1125067207
Карелин Артем
2005-08-26 18:40
2005.10.16
Как получить параметры хранимой процедуры в ADO?


4-1124192100
BFG9k
2005-08-16 15:35
2005.10.16
Звонить в импульсном режиме


14-1127329616
Nick Denry
2005-09-21 23:06
2005.10.16
Народ, а кто какое варенье больше любит?





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский