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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 22.08.2011, 14:09   #1  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
.NET CLR vs X++
Привет всем.

Интересно, кто-нить пробовал замерять насколько быстрее исполняется clr код по сравнению с X++

Вопрос возник по прочтении этого блога :
daxmusings: X++ in the .NET CLR : Life in the Fast Lane
Старый 22.08.2011, 16:50   #2  
lvan is offline
lvan
Участник
Аватар для lvan
Лучший по профессии 2014
 
858 / 82 (4) ++++
Регистрация: 15.04.2011
Записей в блоге: 1
какой код?

логичнее было бы замерить разноску заказа в ax2009 и ax2012
наверняка в маркетинговых материалах на партнерсорсе есть какая-то инфа об ускорении этого или подобного процесса
Старый 23.08.2011, 11:49   #3  
shogel is offline
shogel
Участник
MCBMSS
Соотечественники
 
132 / 169 (6) ++++++
Регистрация: 21.02.2007
Адрес: Finland
Цитата:
Сообщение от lvan Посмотреть сообщение
логичнее было бы замерить разноску заказа в ax2009 и ax2012
наверняка в маркетинговых материалах на партнерсорсе есть какая-то инфа об ускорении этого или подобного процесса
Разноску заказа в DAX2012 очень сильно перепахали, так что сравнение будет не объективным. Самый простой вариант - взять этот метод:
X++:
PurchTable::initFromVendTableIL
и запустить его в среде X++, а потом в .NET. У меня выполнение кода в .NET в среднем дает прирост производительности на 10-15%
__________________
The 50-50-90 rule: Any time you have a 50-50 chance of getting something right, there’s a 90% probability you’ll get it wrong.
Старый 23.08.2011, 12:11   #4  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
А возможно заставить 2012-ю делать разноску заказа не используя IL ?
Это было бы самым объективным сравнением.
Хотя наверно скорость несильно бы отличалась.
Все равно в разноске главное - время ожидания БД.

Надо какую-то другую длительную операцию подобрать. Там где БД меньше дергается.
Старый 23.08.2011, 13:32   #5  
lvan is offline
lvan
Участник
Аватар для lvan
Лучший по профессии 2014
 
858 / 82 (4) ++++
Регистрация: 15.04.2011
Записей в блоге: 1
я думаю, что если постараться, то можно найти такой код, который будет в 10 раз быстрее работать? но зачем?
Старый 23.08.2011, 14:49   #6  
belugin is offline
belugin
Участник
Аватар для belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,622 / 2925 (107) +++++++++
Регистрация: 16.01.2004
Записей в блоге: 5
Цитата:
Сообщение от lvan Посмотреть сообщение
я думаю, что если постараться, то можно найти такой код, который будет в 10 раз быстрее работать? но зачем?
Например, чтобы понимать примерно, насколько ускорится нужный код. То есть, если мы знаем, что в нужном коде быстродействие жрет 50% X++ и 50% SQL и копиляция в CLR даст примерно 70 кратный прирост производительности X++ как такогого, то результирующее ускорение будет примерно в 2 раза.

=== ниже информация неофициальная и, возможно, ложная ===

Насколько я помню тупой код типа цикл с присваиванием переменной укоряется в 70 раз.

Еще есть разные факторы - в .NET используется недетерминированный сборщик мусора, а в X++ детерминированный (он должен убрать мусор сразу как только нет на него ссылок). В результе X++ при каждом присваивании считает циклы - что дает квадратичный, кажется, прирост времени выполнения при присваиваниях полей классов с развесистым графом объектов, например, в разноске больших журналов.

В-общем, попробуйте отпрофилировать TraceParserом ваши задачи.

Еще следует учесть что включение HotSwapping помещает ваши сборки в отдельный домен, что дает некоторое увеличение времени вызова между вашим кодом и ax32serv
За это сообщение автора поблагодарили: mazzy (2), Logger (5), alex55 (1).
Старый 23.08.2011, 15:03   #7  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Цитата:
Сообщение от belugin Посмотреть сообщение
В результе X++ при каждом присваивании считает циклы - что дает квадратичный, кажется, прирост времени выполнения при присваиваниях полей классов с развесистым графом объектов, например, в разноске больших журналов.
Максим, а можно эту тему поподробнее раскрыть ?
Не совсем понятно какие операции приводят к такому сканированию. И как этого избегать в своих разработках.
Старый 23.08.2011, 16:14   #8  
AndyD is offline
AndyD
Участник
КОРУС Консалтинг
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
 
2,560 / 2479 (88) +++++++++
Регистрация: 20.08.2005
Цитата:
Сообщение от Logger Посмотреть сообщение
Максим, а можно эту тему поподробнее раскрыть ?
Поддерживаю.
Не совсем понятно, что имеется в виду.
__________________
Axapta v.3.0 sp5 kr2
Старый 30.11.2011, 18:40   #9  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Цитата:
Сообщение от belugin Посмотреть сообщение
Еще есть разные факторы - в .NET используется недетерминированный сборщик мусора, а в X++ детерминированный (он должен убрать мусор сразу как только нет на него ссылок). В результе X++ при каждом присваивании считает циклы - что дает квадратичный, кажется, прирост времени выполнения при присваиваниях полей классов с развесистым графом объектов, например, в разноске больших журналов.
Хм, получается что если мы пишем метод для передачи параметра-ссылки на объект, то в нем лучше делать минимум присваиваний.
Т.е., например, такой метод :
\Classes\InventUpd_Financial\parmLedgerVoucher
X++:
LedgerVoucher parmLedgerVoucher(LedgerVoucher _ledgerVoucher = ledgerVoucher)
{
    ;
    ledgerVoucher = _ledgerVoucher;
    return ledgerVoucher;
}
на чтение работал бы быстрее при такой реализации (меньше присваиваний) :
X++:
LedgerVoucher parmLedgerVoucher(LedgerVoucher _ledgerVoucher = null)
{
    ;
    if ( !prmIsDefault(_ledgerVoucher) )
    {
        ledgerVoucher = _ledgerVoucher;
    }

    return ledgerVoucher;
}
Старый 01.12.2011, 11:24   #10  
_scorp_ is offline
_scorp_
Участник
Аватар для _scorp_
MCBMSS
 
488 / 369 (13) ++++++
Регистрация: 25.07.2007
Адрес: Москва
Цитата:
Сообщение от Logger Посмотреть сообщение
Хм, получается что если мы пишем метод для передачи параметра-ссылки на объект, то в нем лучше делать минимум присваиваний.
Не забывайте, что в X++ нет inline-функций, следовательно в Вашем примере появятся накладные расходы на вызов функций.
Старый 01.12.2011, 11:43   #11  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Цитата:
Сообщение от _scorp_ Посмотреть сообщение
Не забывайте, что в X++ нет inline-функций, следовательно в Вашем примере появятся накладные расходы на вызов функций.
Это копейки по времени исполнения. Можно забить.
Старый 01.12.2011, 12:33   #12  
lev is offline
lev
Ищущий знания...
Аватар для lev
Oracle
MCBMSS
Axapta Retail User
 
1,723 / 491 (20) +++++++
Регистрация: 18.01.2005
Адрес: Москва
Цитата:
Сообщение от Logger Посмотреть сообщение
...

на чтение работал бы быстрее при такой реализации (меньше присваиваний) :
X++:
LedgerVoucher parmLedgerVoucher(LedgerVoucher _ledgerVoucher = null)
{
    ;
    if ( !prmIsDefault(_ledgerVoucher) )
    {
        ledgerVoucher = _ledgerVoucher;
    }

    return ledgerVoucher;
}
интересно а функция prmIsDefault() всегда корректно отрабатывает в AX2012 и 2009... А то помнится в трешке она почему то иногда некорректно отрабатывала (параметр передан и не равен значению по умолчанию, а функция возвращает true)!
Подробностей уже не помню, но точно помню, что закономерности в сбоях этой функции так и не нашел...
__________________
"Страх перед возможностью ошибки не должен отвращать нас от поисков истины." (с)
С Уважением,
Елизаров Артем
Старый 01.12.2011, 17:14   #13  
belugin is offline
belugin
Участник
Аватар для belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,622 / 2925 (107) +++++++++
Регистрация: 16.01.2004
Записей в блоге: 5
Цитата:
Сообщение от Logger Посмотреть сообщение
Хм, получается что если мы пишем метод для передачи параметра-ссылки на объект, то в нем лучше делать минимум присваиваний.
Не факт, что присваивание, которое не изменяет значение приводит к пересчету циклов
Не факт, что присваивани, которое не изменяет полей объектов приводит к пересчету циклов.

Попробуйте провести эксперимент.
Старый 01.12.2011, 20:33   #14  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Цитата:
Сообщение от belugin Посмотреть сообщение
Не факт, что присваивание, которое не изменяет значение приводит к пересчету циклов
Не факт, что присваивани, которое не изменяет полей объектов приводит к пересчету циклов.

Попробуйте провести эксперимент.
Попробую. Пока правда нет понимания как лучше построить тест.
Когда я оптимизировал разноску закупки с 1000 строк и 8000 записей в логе корреспонденции, то выполнение этого метода
\Classes\InventUpd_Financial\parmLedgerVoucher

Стабильно длилось примерно 4,5 миллисекунды.
Мелочь, конечно, можно и внимания не обращать, но для простого копирования ссылки все же многовато.
Старый 23.08.2011, 13:49   #15  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
В принципе незачем.
Просто интерес.
Старый 23.08.2011, 15:07   #16  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Кстати, по поводу сборки мусора.
Интересно как это все в 2012-й работает. Он теперь там всегда недетерминированный ? Или есть отдельно куча .Net и отдельно X++ и обрабатываются они по разному ?

Думаю это достаточно важный вопрос, так как в X++ в некоторых местах код явно закладывается на то что сразу после присваивания :
X++:
Object = null;
объект Object убивается и ресурсы (например файл на диске если Object - это файл) высвобождаются для работы. А теперь это может быть и не так.
Старый 23.08.2011, 16:41   #17  
plumbum is offline
plumbum
Участник
Соотечественники
 
182 / 86 (3) ++++
Регистрация: 07.12.2007
Адрес: Vienna, AT
Цитата:
Сообщение от Logger Посмотреть сообщение
Кстати, по поводу сборки мусора.
Интересно как это все в 2012-й работает. Он теперь там всегда недетерминированный ? Или есть отдельно куча .Net и отдельно X++ и обрабатываются они по разному ?
Кучи у них разные, как и раньше:

X++, C# Comparison: Object Oriented Programming [AX 2012]

Цитата:
In C#, the System.GC.Collect method in the .NET Framework can be called to start the garbage collector. There is no similar function in X++ because X++ uses a deterministic garbage collector.
Собственно Х++ так и не стал Managed языком, для этого и ввели возможность перекомпилировать Х++ код в .NET код.
__________________
http://www.axdevposts.blogspot.com
Пришел, уведел.... отойди, дай другому увидеть!
Старый 23.08.2011, 16:53   #18  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,952 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Цитата:
Сообщение от plumbum Посмотреть сообщение
Собственно Х++ так и не стал Managed языком...
Что же ему не хватает ?
Старый 23.08.2011, 16:36   #19  
plumbum is offline
plumbum
Участник
Соотечественники
 
182 / 86 (3) ++++
Регистрация: 07.12.2007
Адрес: Vienna, AT
Класический пример плохой работы сборщика мусора в АХ, это перекрестные ссылки между деревом и элементами дерева:

Dynamics AX Performance issue. Cross object references drawbacks


Подробная информация о сборке мусора в X++ и .NET тут
__________________
http://www.axdevposts.blogspot.com
Пришел, уведел.... отойди, дай другому увидеть!
За это сообщение автора поблагодарили: Logger (5).
Старый 23.08.2011, 17:25   #20  
plumbum is offline
plumbum
Участник
Соотечественники
 
182 / 86 (3) ++++
Регистрация: 07.12.2007
Адрес: Vienna, AT
мне кажется просто не хотели переносить фокус на переработку IDE.
Само ядро AX интерпритирует код Х++ в P код, который по своей сути является чем-то вроде MSIL, но "не то"
__________________
http://www.axdevposts.blogspot.com
Пришел, уведел.... отойди, дай другому увидеть!
Теги
.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, время: 09:30.