28.05.2017, 15:20 | #1 |
Участник
|
AX2012. Цель атрибутов в расширении наследования классов
Здравствуйте.
У меня возникли чисто теоретические вопросы. 1. Какая цель создания экземпляров классов через расширенные атрибуты SysExtensionAppClassFactory::getClassFromSysAttribute( ? 2. Чем не устраивает старый дедовский способ construct ? 3. Как при создании экземпляра класса через расширенные атрибуты передать ему параметры в new? ПС. Я исхожу из принципа, что вызывающий класс и так ВСЕГДА должен знать какого наследника он создает. Зачем тогда городить огород и не вызывать просто создание нужного наследника? Типа свич лишний, давайте загрузим ядро, у него голова большая, пусть думает? Или у нас наследники классов растут как грибы, не успеваем исправлять конструктор, нужно через атрибуты это делать?... |
|
|
За это сообщение автора поблагодарили: mazzy (2), Logger (1). |
28.05.2017, 16:01 | #2 |
Banned
|
Как вариант такое обьяснение. Для как бы mapping через metadata, то есть для связки но не трогая код.
Но я конечно не уверен, это так - для темы. Цитата:
есть у вас класс Point с полями X и Y
class Point { public int X {get; set;} public int Y {get; set;} } Вы хотите его сериализовать в JSON. Окей, не вопрос, даже ничего не понадобится. Однако теперь есть проблема, точки нужно отдать в стороннюю библиотеку, где они должны назваться PTXCOORD и PTYCOORD. Естественно, свой код вы захламлять не хотите, у точки есть координаты X и Y, не нужно все эти дебильные прфиксы и суффиксы писать (однако эта библиотека принимает данные только в таком формате. И вот, здравствуйте, атрибуты: [DataContract] class Point { [DataMember(Name = "PTXCOORD ")] public int X {get; set;} [DataMember(Name = "PTYCOORD ")] public int Y {get; set;} } Всё. Ваш код будет работать с нормальными именами, библиотека получит данные в нужном формате, все довольны. Про WCF я и не говорю, там чуть менее чем всё на атрибуты завязано. http://www.cyberforum.ru/csharp-begi...ad1776997.html |
|
28.05.2017, 18:43 | #3 |
Участник
|
В основном все это для того, чтобы при создании наследников не менять существующий код.
Цитата:
старый дедовский способ construct
Цитата:
передать ему параметры в new
Цитата:
вызывающий класс и так ВСЕГДА должен знать какого наследника он создает
|
|
28.05.2017, 22:14 | #4 |
Участник
|
Код в месте, откуда происходит вызов наследников все равно придется менять, так как туда нужно будет передать новый добавленный атрибут для вызова нового наследника.
Шило на мыло. Тут мы добавляем новый атрибут, тут мы добавляем новый пункт свича для создания нужного наследника. Правильное добавление наследника никак не может повлиять на существующий код. Цитата:
Совершенно не оправданное ограничение МС. Приведите хотя бы один довод, почему в конструктор не должны передаваться параметры? Цитата:
Я говорю именно о месте, где производится инициализация объекта нового класса. В этом месте и в этот момент должно быть однозначно известно, какой наследник будет создан. И что это будет определять - атрибут или свич - совершенно все равно. Вопрос - зачем атрибут, если можно через свич легко и просто? |
|
|
За это сообщение автора поблагодарили: mazzy (2), Ace of Database (2). |
28.05.2017, 22:20 | #5 |
Участник
|
Цитата:
Цитата:
Я не говорю о полиморфизме.
Я говорю именно о месте, где производится инициализация объекта нового класса. В этом месте и в этот момент должно быть однозначно известно, какой наследник будет создан. И что это будет определять - атрибут или свич - совершенно все равно. Вопрос - зачем атрибут, если можно через свич легко и просто? |
|
29.05.2017, 03:08 | #6 |
Участник
|
Мне думается вот хорошее видео которое объясняет в целом концепцию
Антон Кекс — Как нам спасти Java https://www.youtube.com/watch?v=TSAlj04_tkA Вкратце - представьте что вас взяли архитектором в Микрософт. если вы предложите писать все через switch, то собственно возникнет вопрос нафиг вы тогда вообще нужны, switch и так все знают. Поэтому собственно идет расширение концепций(при чем принцип чем запутаннее, тем лучше). Вот кстати товарищ Мартин предлагает вообще использовать библиотеку Автофак для подобных вещей goshoom: IoC containers for extensibility если он сумеет продвинуть это, то в следующей версии будем разбираться уже с этим Кстати один из примеров который приводит Антон - это то что на каком то проекте куда они пришли довнедрять было вообще запрещено писать бизнес логику на Джава, все должно быть на SQL. когда начали разбираться откуда пошло это безумное требование, оказалось что если разрешить писать на Джава вещи типа сделать проводку, то получаются конструкции "когда класс создает другой класс чтобы через интерфейс вызвать третий" и т.п. и через некоторое время понять что происходит становится невозможно. SQL этого не позволяется, там собственно всегда можно увидеть что происходит с данными это кстати вспоминается когда приходится отлаживать что-то из Source Framework в Ах. |
|
|
За это сообщение автора поблагодарили: Ace of Database (2). |
29.05.2017, 05:02 | #7 |
Участник
|
Цитата:
Ключевой вопрос: а почему "не мержить свитч" лучше? Ведь use case все равно проверять, все равно придется копать все ветки кода, поскольку все равно останется угроза рефакторинга остальных веток кода. Все равно придется расширять test cases, все равно придется дописывать документацию, все равно придется обеспечивать совместимость. Атрибут и свитч - это настолько небольшая часть работы в общем проекте. Но технология атрибутов получилась настолько отличной от остальной работы. Так вот: а почему "не мержить свитч" лучше? Цитата:
Хоть и очень толковый. Но он судит людей по себе. На самом деле все проще. Как и остальные люди, специалисты в МС хотят сделать лучше, проще, быстрее. Просто "критерии лучшести" в МС сильно отличаются от остальных людей. Можно много говорить на тему "почему отличаются". Это отдельная тема. Но как бы то ни было, получаются решения типа советских панельных домов. Которые получались неудобными для жилья, очень затратными в части отопления, дорогими в части перевозки (панелевоз всегда ездил порожняком со стройки в сторону панельного завода). Но зато сроки строительства минимальны и стоимость производства панелей минимальна за счет массового производства, а удобство-отопление-перевозки не включались расчет при оптимизации. |
|
29.05.2017, 07:45 | #8 |
Участник
|
Последний раз редактировалось S.Kuskov; 29.05.2017 в 07:54. |
|
29.05.2017, 07:58 | #9 |
Участник
|
а также доп.вопросы к SysExtension framework:
Kashperuk Ivan: Development tutorial: SysExtension framework in factory methods where the constructor requires one or more arguments |
|
29.05.2017, 08:51 | #10 |
Участник
|
Цитата:
Сообщение от mazzy
Угу.
Ключевой вопрос: а почему "не мержить свитч" лучше? Ведь use case все равно проверять, все равно придется копать все ветки кода, поскольку все равно останется угроза рефакторинга остальных веток кода. Все равно придется расширять test cases, все равно придется дописывать документацию, все равно придется обеспечивать совместимость. |
|
29.05.2017, 08:58 | #11 |
Участник
|
)
Цитата:
экономия предназначена только для инженеров МС, проявляется только внутри МС и в только на environment МС, в ходе достижения целей, которые существуют только внутри МС. любое последствие (хорошее или плохое) для других пользователей (клиенты, партнеры) - это скорее всего побочный эффект. причем, скорее всего, незапланированный заранее побочный эффект. ) Последний раз редактировалось mazzy; 29.05.2017 в 09:07. |
|
|
За это сообщение автора поблагодарили: ta_and (3), apanko (3). |
29.05.2017, 09:31 | #12 |
Участник
|
|
|
29.05.2017, 11:00 | #13 |
Участник
|
Цитата:
В последующем времени, вероятно, все больше кода будет закрыто и опечатано сей корпорацией.
__________________
// no comments |
|
29.05.2017, 11:06 | #14 |
Участник
|
Цель МС давно известна - заработать.
"Сделать разделение кода" не является (и не может являться) целью корпорации МС ))) |
|
29.05.2017, 11:17 | #15 |
Участник
|
Давайте отвечу публично:
Нет, это не придирки к русскому языку и правописанию. Допустим, что в утверждении подразумевался не МС, а некие мифические "разработчики МС". Тогда получается утверждение "Цель разработчиков МС давно известна - сделать разделение кода". Но при этом утверждение, что "цель корпорации МС - заработать" остается верным. Отсюда тривиальный вопрос - а как выполнение цели этих мифических разработчиков МС позволит выполнить цель корпорации МС? каков механизм? На самом деле вопросов встает очень много. Это если нормально сформулировать мысль, не делая никаких неоправданных логических допущений. |
|
29.05.2017, 11:35 | #16 |
Administrator
|
Все просто. Прибыль, как известно - это доходы минус расходы. Для увеличения прибыли надо увеличивать доходы и уменьшать расходы. Уменьшение трудозатрат МСа при выпуске новых версий даст возможность уменьшить расходы. Вполне вероятно, что существенное уменьшение расходов МСа повлечет за собой несущественное уменьшение стоимости лицензий (=доходов). Т.е. даст возможность существенно увеличить прибыль .
Так что если какая-то технология нужна исключительно МСу и позволяет ему снизить свои издержки - то эта технология будет, даже если она не нужна ни партнерам ни клиентам.
__________________
Возможно сделать все. Вопрос времени |
|
|
За это сообщение автора поблагодарили: mazzy (2). |
29.05.2017, 11:45 | #17 |
Участник
|
Логично, чё!
Цитата:
Прямой вопрос к твоему тексту: А как "уменьшение трудозатрат МСа" повлияет на число купленных лицензий (доход)? Увеличит? Сохранит на прежнем уровне? Уменьшит? Почему? Косвенный вопрос: dech сказал "сделать разделение кода" ты говоришь "Уменьшение трудозатрат ..., технология ... позволяет ему снизить свои издержки" а "разделение кода" точно позволит МСу "снизить свои издержки"? каков механизм? )))) В общем, ребяты, давайте тщательнее. Пожалуйста. Последний раз редактировалось mazzy; 29.05.2017 в 11:51. |
|
29.05.2017, 11:52 | #18 |
Участник
|
В теории, разумеется, этого нет. Но Axapta - это не "теория". Это "экземпляр" теории Конкретная реализация, которая, разумеется, вводит свои собственные ограничения
Цитата:
classfactory.createClass(classId); передача параметров здесь не предусмотрена "в принципе". Все "параметры" поднимаются из unpack уже "потом". После инициализации Разумеется, пакетные задания - отдельный разговор, но, вообще-то, в Axapta довольно много разных обслуживающих процедур, которые требуют создание экземпляра класса для выполнения какого-либо анализа по структуре класса. Если у Вас в метод new передается какой-либо параметр, то есть риск получить Exception в момент создания экземпляра. Как следствие, весь функционал перестает работать Собственно, сделайте поиск по перекрестным ссылкам, где используется хотя бы classfactory.createClass() не говоря уже о DictClass.makeObject(). Удивитесь как много подобных вызовов Поэтому, чтобы не получить проблему "на ровном месте" в среде Axapta следует жестко придерживаться правила Никаких параметров в методах new Да, в большинстве случаев, у Вас проблем не будет, если Вы передадите параметр в new. Но однажды, в самый неподходящий момент, все "вдруг" перестанет работать
__________________
- Может, я как-то неправильно живу?! - Отчего же? Правильно. Только зря... |
|
|
За это сообщение автора поблагодарили: mazzy (10). |
29.05.2017, 11:57 | #19 |
Участник
|
Цитата:
Сообщение от Владимир Максимов
Собственно, сделайте поиск по перекрестным ссылкам, где используется хотя бы classfactory.createClass() не говоря уже о DictClass.makeObject(). Удивитесь как много подобных вызовов
Поэтому, чтобы не получить проблему "на ровном месте" в среде Axapta следует жестко придерживаться правила Никаких параметров в методах new Да, в большинстве случаев, у Вас проблем не будет, если Вы передадите параметр в new. Но однажды, в самый неподходящий момент, все "вдруг" перестанет работать а давайте вернемся к исходному вопросу? Цитата:
Сообщение от ta_and
Здравствуйте.
У меня возникли чисто теоретические вопросы. 1. Какая цель создания экземпляров классов через расширенные атрибуты SysExtensionAppClassFactory::getClassFromSysAttribute( ? 2. Чем не устраивает старый дедовский способ construct ? 3. Как при создании экземпляра класса через расширенные атрибуты передать ему параметры в new? ПС. Я исхожу из принципа, что вызывающий класс и так ВСЕГДА должен знать какого наследника он создает. Зачем тогда городить огород и не вызывать просто создание нужного наследника? Типа свич лишний, давайте загрузим ядро, у него голова большая, пусть думает? Или у нас наследники классов растут как грибы, не успеваем исправлять конструктор, нужно через атрибуты это делать?... довести до ответов на исходные вопросы? |
|
29.05.2017, 12:01 | #20 |
Участник
|
да, рекомендация "Никаких параметров в методах new" хороша с точки зрения партнера и клиента. но рискну задать вопрос с позиции вендора.
да, classfactory.createClass() и DictClass.makeObject() используется дофига где. существуют ли на ваш взгляд более оптимальные (для всех причастных к аксапте) решения нежели "Никаких параметров в методах new"? |
|
Теги |
sysextension framework, sysoperation framework, как правильно, полезное |
|
|