AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Программирование
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 21.04.2006, 09:31   #1  
Lucky13 is offline
Lucky13
Участник
1C
 
714 / 198 (8) ++++++
Регистрация: 21.10.2004
Критерий начала "сборки мусора"
Подскажите, пожалуйста, что это за критерий такой и как он влияет на сборку мусора. В help написано: Число открытых элементов до начала процедуры очичтки динамической памяти. Что в данном случае понимается по элементом?
Старый 21.04.2006, 13:40   #2  
AndyD is offline
AndyD
Участник
КОРУС Консалтинг
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
 
2,560 / 2479 (88) +++++++++
Регистрация: 20.08.2005
Developer's Guide - Garbage collection limit
Цитата:
Number of application objects no longer in use.

MorphX automatically performs garbage collection when the number given here is reached.

The system uses memory each time an application object is opened in the Application Object Tree. Unless a value is given here, application objects are never discarded from memory.

Additional info:

An application object is considered open when
  • The application object's node is expanded in the AOT, or
  • One of the application object's methods is open in the X++ editor, or
  • The application object's properties are displayed, or
  • The application object is displayed in the visual form editor or in the visual report editor, or
  • The application object is 'touched', that is, it has been changed but not yet saved.

An application object is subject to garbage collection when one of the above mentioned states have happened, and none of them are true any more.

The next time a garbage collected application object is opened, it is reloaded from external storage to system memory.

Note
Garbage collection is one of the three components in an update cycle, and is performed only when an update cycle interval is given (the Auto-Update option).
__________________
Axapta v.3.0 sp5 kr2
Старый 21.04.2006, 14:01   #3  
Lucky13 is offline
Lucky13
Участник
1C
 
714 / 198 (8) ++++++
Регистрация: 21.10.2004
2 AndyD
Это я уже видел. Из выше указанного не ясно как именно работает сборщик мусора - в каком случае объект считается не используемым?
В общем интересен следующий вопрос: если в методе класса создается 1000 объектов другого класса когда занятая ими память будет освобождена и влияет ли выше указанный параметр на освобождение памяти?
Старый 21.04.2006, 14:06   #4  
Андре is offline
Андре
Moderator
Сотрудники компании GMCS
 
2,375 / 464 (20) +++++++
Регистрация: 03.12.2001
Цитата:
Из выше указанного не ясно как именно работает сборщик мусора - в каком случае объект считается не используемым?
Думаю, что так же, как и в других языках программирования - например, Java и C#. Объект считается неиспользуемым, если счетчик указателей на этот объект стал равен 0.
Более подробно про управление памятью в net можно почитать здесь: http://www.rsdn.ru/article/dotnet/GCnet.xml
Старый 21.04.2006, 14:18   #5  
Lucky13 is offline
Lucky13
Участник
1C
 
714 / 198 (8) ++++++
Регистрация: 21.10.2004
С Java и C# все ясно, но в X++ сдается мне что все не совсем так. Во-первых, обычно все объекты обычно наследуются (иногда неявно) от какого-то общего класса который управляет памятью. В X++, хотя методы new и finalize можно перекрыть (значит они имеются у класса предка), но метода super() они почему-то не содержат. Во-вторых, если требуется много памяти, то она после окончания работы класса Axapta, она освобождается не сразу, а через несколько минут. Возможно память освобождается средствами Windows (очистка неиспользуемых страниц), а не Axapta. Все это заставляет задуматься, как же все таки работает загадочный сборщик мусора в Axapta и можно ли управлять его работой.
Старый 21.04.2006, 14:27   #6  
Андре is offline
Андре
Moderator
Сотрудники компании GMCS
 
2,375 / 464 (20) +++++++
Регистрация: 03.12.2001
Цитата:
Во-вторых, если требуется много памяти, то она после окончания работы класса Axapta, она освобождается не сразу, а через несколько минут.
Ну, в dot net сборщик мусора тоже не сразу уничтожает объекты.

Цитата:
Возможно память освобождается средствами Windows (очистка неиспользуемых страниц), а не Axapta.
Разработчики Аксапты не разрабатывали свой менеджер памяти, а использовали уже существующий. Какой именно - уже не помню, хотя мужественно пытался сделать это последние несколько минут. Может быть вот этот (http://www.microquill.com/), хотя, честно говоря, не уверен.
Если ошибаюсь - пусть меня поправят.
Старый 21.04.2006, 14:29   #7  
AndyD is offline
AndyD
Участник
КОРУС Консалтинг
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
 
2,560 / 2479 (88) +++++++++
Регистрация: 20.08.2005
Классы, формы и т.д. создаваемые динамически (т.е. в процессе выполнения кода, вызова MenuItems и т.д.) размещаются в области памяти SmartHeap (можно увидет в форме SysHeapCheck). Они удалются из памяти при явном освобождении или при выходе из области видимости. Сама использованная память возвращается в пул памяти SmartHeap и помечается как свободная. SmartHeap управляет памятью по своим алгоритмам. В Axapta есть класс для управления SmartHeap - HeapCheck. Один из его методов - shrinkpool() предназначен для освобождение неиспользованной памяти. Но не забывайте, что память может быть фрагментирована - по-этому эффект от его использования может быть незначительный.
Поищите на форме по SmartHeap - этот вопрос уже обсуждался
__________________
Axapta v.3.0 sp5 kr2
Старый 21.04.2006, 14:45   #8  
AndyD is offline
AndyD
Участник
КОРУС Консалтинг
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
 
2,560 / 2479 (88) +++++++++
Регистрация: 20.08.2005
Что касается сабжевого параметра, то его предназначение - управление памятью, используемой AOT при работе со своими элементами - для каждого из них происходит выделение памяти при выполении с ними операций из приведенного мной списка.
После завершения работы с ними (т.е. сворачивания ветви, закрытия редактора и т.д.) эти объекты удаляются из памяти, если их кол-во доходит до этого параметра и пользователь (точнее разработчик) некоторое время (параметр Auto-Update) не выполняет никаких действий в системе.
__________________
Axapta v.3.0 sp5 kr2
Старый 21.04.2006, 19:02   #9  
belugin is offline
belugin
Участник
Аватар для belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,622 / 2925 (107) +++++++++
Регистрация: 16.01.2004
Записей в блоге: 5
База знаний ERP : Axapta / Управление Памятью
За это сообщение автора поблагодарили: alex55 (1).
Теги
сборка мусора, управление памятью

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Задать критерий типа !="" bobski DAX: Программирование 3 29.12.2008 08:23
Почему на форме "Пользовательские настройки", когда я перехожу в нее из формы, отсутствует закладка "Запрос"? Hans DAX: Администрирование 0 05.07.2007 13:52
Тендер на внедрение модуля "Управление персоналом" и "Расчеты с персоналом" Oxsana DAX: Прочие вопросы 5 02.05.2006 19:47
Превышение кол-ва в "немедленная поставка" кол-ва "к поставке" Pegiy DAX: Функционал 16 23.03.2004 20:03
"LIKE" и "OR" в "qbds" @x DAX: Программирование 14 20.01.2004 13:20

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 19:30.