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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 23.08.2011, 17:37   #1  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,973 / 3268 (116) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Не совсем понимаю, в чем проблема.
А что вы подразумеваете под Managed языком ?

Последний раз редактировалось Logger; 23.08.2011 в 17:57.
Старый 23.08.2011, 18:59   #2  
plumbum is offline
plumbum
Участник
Соотечественники
 
182 / 86 (3) ++++
Регистрация: 07.12.2007
Адрес: Vienna, AT
Цитата:
Сообщение от Logger Посмотреть сообщение
Не совсем понимаю, в чем проблема.
А что вы подразумеваете под Managed языком ?
Я подразумеваю, что Managed языки, это те языки, на которых может писаться Managed код

Проблема была в том, что МС не хотели ламать то, что уже было в АХ. Они просто берут Р код, созданный компилятором, и его переводят потом в MSIL, а MSIL, как известно, может быть интерпритирован в любой язык, поддерживаемый .NET платформой. Но сам по себе X++ так и не стал "новым официальным языком .NET".

Это было скорее стратегиское решение. Думаю что в последующих версиях X++ будет становиться все меньше и меньше, пока они полностью не перейдут на Managed код.
__________________
http://www.axdevposts.blogspot.com
Пришел, уведел.... отойди, дай другому увидеть!
Старый 24.08.2011, 23:58   #3  
belugin is offline
belugin
Участник
Аватар для belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,622 / 2925 (107) +++++++++
Регистрация: 16.01.2004
Записей в блоге: 5
Цитата:
Сообщение от plumbum Посмотреть сообщение
Проблема была в том, что МС не хотели ламать то, что уже было в АХ. Они просто берут Р код, созданный компилятором, и его переводят потом в MSIL
Интересно, что это происходит через XML каковой можно получить через API. То есть на DictXXX классах есть методы, представляющие P-Code в виде XML.
Старый 23.08.2011, 20:42   #4  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,973 / 3268 (116) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Где-то проходила инфа что x++ чуть ли не Visual Studio появится. Возможно передумали.
Старый 23.08.2011, 21:34   #5  
AndyD is offline
AndyD
Участник
КОРУС Консалтинг
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
 
2,560 / 2494 (89) +++++++++
Регистрация: 20.08.2005
Цитата:
Сообщение от plumbum Посмотреть сообщение
Класический пример плохой работы сборщика мусора в АХ, это перекрестные ссылки между деревом и элементами дерева:

Dynamics AX Performance issue. Cross object references drawbacks
Не уловил, в чем здесь пример плохой работы GC.
По-моему, больше похоже на проблемы с быстродействие самого TreeView при большом количестве элементов и уровне вложенности. И с большим расходом памяти на непонятно зачем нужные объекты (я про хранение ссылок на FormTreeItem)

Цитата:
Сообщение от plumbum Посмотреть сообщение
Подробная информация о сборке мусора в X++ и .NET тут
Не понял, на что здесь надо обратить внимание в контексте высказывания belugin.
Что это за циклы в каждом присваивании на X++?
__________________
Axapta v.3.0 sp5 kr2
Старый 24.08.2011, 00:19   #6  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5803 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
Цитата:
Сообщение от AndyD Посмотреть сообщение
Что это за циклы в каждом присваивании на X++?
Была в блоге команды разработчиков X++ статья X++: Garbage Collection and Ax Performance Whitepaper (занятно, сейчас ее в блоге не найти), там объяснялось, что детерминированный сборщик мусора в X++ поддерживает для каждого объекта два счетчика: один - для учета ссылок на объект (reference count) и второй - для учета "петель" ссылок (loop count), в которых участвует объект.

Объект не подлежит уничтожению до тех пор, пока число ссылок на него больше числа "петель" ссылок, в которых он участвует. Так вот, при каждом присваивании переменной ссылки на тот или иной объект сборщик мусора должен не только увеличить счетчик ссылок на этот объект, но и по графу ссылок между объектами пересчитать счетчик "петель" для него. А длительность последней операции с увеличением числа связанных между собой объектов имеет тенденцию расти экспоненциально.

Последний раз редактировалось gl00mie; 24.08.2011 в 00:30. Причина: еще картинка
За это сообщение автора поблагодарили: Logger (5), plumbum (1), Mileyko (1).
Старый 24.08.2011, 00:52   #7  
plumbum is offline
plumbum
Участник
Соотечественники
 
182 / 86 (3) ++++
Регистрация: 07.12.2007
Адрес: Vienna, AT
Цитата:
Не уловил, в чем здесь пример плохой работы GC.
собственно на примере показано, что при росте петель падает прозиводительность, так как сборщик мусора эти самые петли всега анализирует.

К сожалению не нашел сразу ссылку на вышеуказанную статью. Моя ссылка на MSDN подтверждала то, что GC в X++ детерминированный (там так и было написано).

Вот сейчас из блогов пришла статья о возможности скомпилировать X++ в IL.
X++ in the .NET CLR : Life in the Fast Lane

Там ремарка, о том, что при отладке IL, созданного из X++, код последнего выбирается фактически из AOT, а вот выполняется как раз прекомпилированная сборка. Я так понимаю, что обратное преобразование из IL в X++ не реализовано. Посему и не считаю что X++ таки стал Managed .NET Language.
__________________
http://www.axdevposts.blogspot.com
Пришел, уведел.... отойди, дай другому увидеть!

Последний раз редактировалось plumbum; 24.08.2011 в 01:14.
За это сообщение автора поблагодарили: Logger (1).
Старый 01.12.2011, 13:26   #9  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,973 / 3268 (116) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Ужас.
Не знал про такие глюки.
Может вспомните при каких условиях было ?
Старый 01.12.2011, 13:28   #10  
lev is offline
lev
Ищущий знания...
Аватар для lev
Oracle
MCBMSS
Axapta Retail User
 
1,723 / 491 (20) +++++++
Регистрация: 18.01.2005
Адрес: Москва
Цитата:
Сообщение от Logger Посмотреть сообщение
Ужас.
Не знал про такие глюки.
Может вспомните при каких условиях было ?
будет под рукой трешка и свободное время, поэксперементирую, дабы освежить воспоминания .
По результатам отпишусь.
__________________
"Страх перед возможностью ошибки не должен отвращать нас от поисков истины." (с)
С Уважением,
Елизаров Артем
Старый 01.12.2011, 13:48   #11  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,973 / 3268 (116) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Вы не путаете со случаем когда в качестве параметра передается значение совпадающее со значением по умолчанию ? В таких случаях prmIsDefault() возвращает false и это правильно. Т.е. эта функция не просто значения сравнивает, а на самом деле смотрит передано что-то было или нет.
Старый 01.12.2011, 14:10   #12  
lev is offline
lev
Ищущий знания...
Аватар для lev
Oracle
MCBMSS
Axapta Retail User
 
1,723 / 491 (20) +++++++
Регистрация: 18.01.2005
Адрес: Москва
Цитата:
Сообщение от Logger Посмотреть сообщение
Вы не путаете со случаем когда в качестве параметра передается значение совпадающее со значением по умолчанию ? В таких случаях prmIsDefault() возвращает false и это правильно. Т.е. эта функция не просто значения сравнивает, а на самом деле смотрит передано что-то было или нет.
Не, это понятно. Она и должна проверять, передано что нибудь или нет, а не сверять похожесть значений переданного и поумолчанию.

В памяти есть некие смутные воспоминания с чем это было связано, но пока не проверю не хочу озвучивать, что бы не сбивать общественность с толку
__________________
"Страх перед возможностью ошибки не должен отвращать нас от поисков истины." (с)
С Уважением,
Елизаров Артем
Старый 01.12.2011, 16:15   #13  
lev is offline
lev
Ищущий знания...
Аватар для lev
Oracle
MCBMSS
Axapta Retail User
 
1,723 / 491 (20) +++++++
Регистрация: 18.01.2005
Адрес: Москва
Цитата:
Сообщение от Logger Посмотреть сообщение
Вы не путаете со случаем когда в качестве параметра передается значение совпадающее со значением по умолчанию ? В таких случаях prmIsDefault() возвращает false и это правильно. Т.е. эта функция не просто значения сравнивает, а на самом деле смотрит передано что-то было или нет.
Погонял разные варинаты использования этой функции, никаких проблем не выявилось...
Одно из трех,
  1. либо я не смог воссосздать ту ситуацию, с которой сталкивался ранее;
  2. либо это была плавыющая ошбка и в одной и той же ситуации то воспроизводиласть, то нет;
  3. либо я что-то путаю, и проблема была не в этой функции.

надеюсь, что это третий вариант
__________________
"Страх перед возможностью ошибки не должен отвращать нас от поисков истины." (с)
С Уважением,
Елизаров Артем
Старый 01.12.2011, 16:24   #14  
ivas is offline
ivas
Участник
Аватар для ivas
 
252 / 68 (3) ++++
Регистрация: 22.12.2005
Цитата:
Сообщение от lev Посмотреть сообщение
Погонял разные варинаты использования этой функции, никаких проблем не выявилось...
Одно из трех,
  1. либо я не смог воссосздать ту ситуацию, с которой сталкивался ранее;
  2. либо это была плавыющая ошбка и в одной и той же ситуации то воспроизводиласть, то нет;
  3. либо я что-то путаю, и проблема была не в этой функции.

надеюсь, что это третий вариант
Кажется с енумами была такая проблема в 3ке, при передаче 0 ф-ия возвращала true
__________________
aLL woRk aNd nO JoY MAKes jAck a dULL Boy
Старый 01.12.2011, 16:33   #15  
lev is offline
lev
Ищущий знания...
Аватар для lev
Oracle
MCBMSS
Axapta Retail User
 
1,723 / 491 (20) +++++++
Регистрация: 18.01.2005
Адрес: Москва
Цитата:
Сообщение от ivas Посмотреть сообщение
Кажется с енумами была такая проблема в 3ке, при передаче 0 ф-ия возвращала true
вот я тоже так думал, но при тесте функция отработала нормально
__________________
"Страх перед возможностью ошибки не должен отвращать нас от поисков истины." (с)
С Уважением,
Елизаров Артем
За это сообщение автора поблагодарили: Logger (3).
Старый 01.12.2011, 16:52   #16  
ivas is offline
ivas
Участник
Аватар для ivas
 
252 / 68 (3) ++++
Регистрация: 22.12.2005
Цитата:
Сообщение от lev Посмотреть сообщение
вот я тоже так думал, но при тесте функция отработала нормально
на чистой 3ке без сп и кр проверяли?
__________________
aLL woRk aNd nO JoY MAKes jAck a dULL Boy
Теги
.net, x++, полезное, сборка мусора

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
daxmusings: X++ in the .NET CLR : Life in the Fast Lane Blog bot DAX Blogs 0 22.08.2011 10:11
AX.NET: интеграция .NET-приложений с Аксаптой и (будущие) возможности облачных вычислений gl00mie DAX: Программирование 2 23.04.2010 00:47
jinx: Microsoft Dynamics AX - X++ und .NET (CLR) Arrays Blog bot DAX auf Deutsch 0 03.03.2009 03:08
Dynamics AX: DAXguy - DAX and the .Net CLR Blog bot DAX Blogs 0 27.10.2007 04:23
Inside Dynamics AX 4.0: Working with the .NET Business Connector Blog bot DAX Blogs 0 04.10.2007 05:15

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

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

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