Russian Qt Forum

Компиляторы и платформы => Windows => Тема начата: OKTA от Март 27, 2014, 14:43



Название: [РЕШЕНО] GlobalFree
Отправлено: OKTA от Март 27, 2014, 14:43
Товарищи, возник вопрос!
Имею приложение, которое подключает библиотеку(Lib1), которая подключает библиотеку(Lib2)  ;D
В какой-то момент Lib1 вызывает метод Lib2 в параметрах которого передается указатель void. Lib2 у себя выделяет память под необходимый объект и возвращает в Lib1 указатель на созданный объект, но когда я пытаюсь удалить этот объект из Lib1 через delete, возникает исключение AccessViolationError(которое, кстати говоря, почему-то не отлавливается - вижу его в дебаггере), а если через GlobalFree, то все ок. В чем проблема? В Lib2 каким-то хитрым образом выделяется память? Или что?  ???

Попробовал - LocalFree тоже работает правильно 0_о
Через free не работает.
А как реализовано все в Lib2 не могу посмотреть.  :'(


Название: Re: GlobalFree
Отправлено: OKTA от Март 27, 2014, 15:08
И так.. Кажется проблема решена.
1. Глобальные функции управления памятью и локальные функции в винде - это одно и тоже в данное время  ;D
2. Delete и free не срабатвают, потому что память заблокирована вызовом GlobalLock в Lib2
3. Lib2 использует GlobalAlloc, GlobalFree и т.д..

 ???


Название: Re: GlobalFree
Отправлено: OKTA от Март 27, 2014, 17:03
Возникают вопросы:
1) где и как выделяется память через GlobalAlloc(LocalAlloc) в отличии от new и malloc?
2) GlobalLock(LocalLock) - позволяют выделять память с некоторым количеством атрибутов http://msdn.microsoft.com/en-us/library/windows/desktop/aa366574(v=vs.85).aspx Позволяет ли тоже самое делать new?

Читаю мануалы в msdn и ничего не понимаю  :'(


Название: Re: GlobalFree
Отправлено: Igors от Март 27, 2014, 17:51
Возникают вопросы:
1) где и как выделяется память через GlobalAlloc(LocalAlloc) в отличии от new и malloc?
2) GlobalLock(LocalLock) - позволяют выделять память с некоторым количеством атрибутов http://msdn.microsoft.com/en-us/library/windows/desktop/aa366574(v=vs.85).aspx Позволяет ли тоже самое делать new?

Читаю мануалы в msdn и ничего не понимаю  :'(
Это все уже мхом поросло. Оно было бездарно содрано с MacOS еще в те времена когда виртуальной памяти не было (ну или юзалась через драйвера). Смысл - если блок залочен, то его адрес не меняется (можно использовать) и гарантируется что его никто не грохнет. Клиент должен был сначала залочить хендлер, попользоваться и разлочить, дальше ОС разберется выгружать или как. С виртуальной памятью все это стало ненужно, поэтому new этого не делает.


Название: Re: GlobalFree
Отправлено: OKTA от Март 27, 2014, 17:56
Возникают вопросы:
1) где и как выделяется память через GlobalAlloc(LocalAlloc) в отличии от new и malloc?
2) GlobalLock(LocalLock) - позволяют выделять память с некоторым количеством атрибутов http://msdn.microsoft.com/en-us/library/windows/desktop/aa366574(v=vs.85).aspx Позволяет ли тоже самое делать new?

Читаю мануалы в msdn и ничего не понимаю  :'(
Это все уже мхом поросло. Оно было бездарно содрано с MacOS еще в те времена когда виртуальной памяти не было (ну или юзалась через драйвера). Смысл - если блок залочен, то его адрес не меняется (можно использовать) и гарантируется что его никто не грохнет. Клиент должен был сначала залочить хендлер, попользоваться и разлочить, дальше ОС разберется выгружать или как. С виртуальной памятью все это стало ненужно, поэтому new этого не делает.

А где в итоге GlobalAlloc выделяет память? В виртуальной памяти в наши времена?


Название: Re: GlobalFree
Отправлено: Igors от Март 27, 2014, 18:30
А где в итоге GlobalAlloc выделяет память? В виртуальной памяти в наши времена?
Цитированием не злоупотребляйте :) "В итоге" в виртуальной, др ходов сейчас нет. GlobalAlloc может еще ничего не выделять, он создает handle на блок памяти, который будет готов к использованию после GlobalLock, а тот отдаст клиенту адрес со смещением, и удалить с помощью delete не удастся. Короче - чем выделяли тем и освобождайте (парной ф-цией)



Название: Re: GlobalFree
Отправлено: OKTA от Март 27, 2014, 18:54
Спасибо ;)


Название: Re: GlobalFree
Отправлено: Akon от Март 28, 2014, 10:38
Как вообще можно смешивать ф-ии из библиотеки C/C++ (new, malloc, delete, free) с API? Используйте либо то, либо другое.


Название: Re: GlobalFree
Отправлено: OKTA от Март 28, 2014, 11:01
Как только я приступил к задаче, я не знал, каким образом закрытая библиотека работает с памятью. Выяснил уже после, потому и вопросы такие  ;)