Композиция сүзгілері - Википедия - Composition filters

The композициялық сүзгілер модель әдеттегі модульдік кеңейтуді білдіреді объект моделі. Ол үлкен және күрделі қосымшаларды құрудағы көптеген мәселелерді шешуге мүмкіндік береді. Ең бастысы, композициялық сүзгілердің біреуі an абстракция қабаты хабарлама жіберетін жүйелер үшін.

Композициялық сүзгілер кіріс және шығыс хабарламаларын манипуляциялау арқылы объектінің әрекетін өзгерту арқылы жұмыс істейді. Бұл шарттармен басқарылатын кіріс және шығыс сүзгілерінің көмегімен жасалады.

Тарих және мотивация

Жылы қатарлас және таратылды есептеу, көптеген мәселелер бар, мысалы, шашырау және шатастыру, бұл дәстүрлі қолдану қиын болды объект - бағдарланған модельдер. Бағдарламалық жасақтаманы әзірлеудің жаңа қажеттілігі туындады, ол осы мәселелерді шешті және нәтижесінде пайда болды Бағдарламалық жасақтаманың аспектілігіне негізделген парадигма. Осы парадигмадағы бірнеше модельдер бір уақытта жасалды және олардың бірі - бұл композициялық сүзгілердің объектілік моделі. Бұл модельдің ізашарлары Мехмет Аксит және әр түрлі PhD докторанттар (Лодейвик Бергманс, Ян Бош, Бедир Текинердоган) және көптеген магистрлер болды. TRESE тобының студенттері Твенте университеті Нидерландыда. Оның негізі сина тілі болды [1][2] оны Мехмет Аксит кандидаттық диссертациясында жасаған. Содан бері модельде көптеген жетістіктер жасалды.[3][4]

Дизайн

Композициялық сүзгілер моделінің дизайны - ядро ​​объектісі моделінің дизайнын кеңейту. Дизайн екі негізгі бөліктен тұрады - ядро ​​немесе іске асыру бөлігі, сыртқы қабаты немесе интерфейс бөлігі. Кеңейтімдер интерфейс бөлігінде дәстүрлі ядро ​​нысаны моделінен композициялық сүзгілер моделін шығару үшін жасалады.[5]

Іске асыру бөлігі

Іске асыру бөлігі немесе ядросы үш түрдегі компоненттерден тұратын бір қабаттан тұрады:

  1. Дәлелді айнымалылар
  2. Әдістер
  3. Шарттар

Ол сонымен қатар интерфейс қабаттары мен іске асыруды бөлетін инкапсуляция шекарасынан тұрады.

Дәлелді айнымалылар

Instance айнымалылары - ядро ​​құрамына кіретін жалғыз компонент. Бұл айнымалыларға шекарадан тыс қол жеткізу мүмкін емес. Бұл модельде Instance айнымалылары кез келген типте болуы мүмкін. Тұтас сандар, символдар сияқты алғашқы деректер типтері және пайдаланушылар анықтаған деректер типтері, мысалы, сыныптар мен санамалар, барлық кездейсоқ айнымалылар болып саналады.

Әдістер

Нысанның тәртібі оның әдістері арқылы жүзеге асырылады. Әдіс екі бөлімнен тұрады - әдіс денесі және әдіс декларациясы. Нысанның шақырылуы бойынша орындалуы күтілетін әрекеттер әдіс денесінде анықталады. Әдіс декларациясы әдіс атауынан, параметрлердің атауы мен түрінен және қайтару түрінен тұрады. Әдістер ядрода толығымен қамтылмаған және оларды интерфейс бөлігінде қолдануға болады.

Бастапқы әдіс

Бастапқы әдіс - функциясына ұқсас арнайы әдіс құрылысшылар басқа объектіге бағытталған модельдерде.

Шарттар

Логикалық қайтару типі және бос параметрлер тізімі бар әдіс шарт деп аталады. Шарттарды объектінің ағымдағы күйі туралы ақпарат беру үшін пайдалануға болады. Әдістерге ұқсас шарттарды интерфейс бөлігінде де қолдануға болады және шарттардың көп бөлігі қолдану бөлігінен тыс болады.

Интерфейс бөлігі

Композициялық сүзгілер объектісінің моделінің интерфейс бөлігі екі негізгі компоненттен тұрады - кіріс және шығыс сүзгілері. Оның құрамында екі тірек компонент бар - ішкі және сыртқы. Сонымен қатар, интерфейс бөлігінен іске асыру бөлігінің әдістері мен шарттарына қол жеткізуге болады.

Сүзгілер

Кіріс және шығыс сүзгілері дизайны бойынша ұқсас, бірақ функционалдығы бойынша әр түрлі. Кіріс сүзгілеріне объектіге жіберілетін хабарламалармен жұмыс жасау тапсырылады, ал шығыс сүзгілері объект жіберетін хабарламаларға жауап береді. Сүзгілердің негізгі қызметі - келіп түскен хабарламалармен жұмыс жасау және оларды келесі қабатқа жіберу. Сүзгілер қабаттар түрінде жасалған, хабарлама келесі қабатқа өту үшін бір қабаттан өтуі керек. Әр қабат әр түрлі сүзгілерден тұруы мүмкін. Әрбір сүзгі белгілі бір үлгіні көрсетеді. Үлгі кіріс немесе шығыс хабарлама сәйкес келуі керек синтаксисті анықтайды. Хабарлама келгенде екі мүмкіндік пайда болады - хабарламаны сүзгі қабылдамайды немесе сүзгі басқарады. Хабарды қабылдамау немесе манипуляциялау тәсілі сүзгінің түріне байланысты.

Сүзгінің дизайны

Сүзгі сүзгі элементінің жиынтығының көмегімен жасалған. Бұл жиын әр хабарлама солдан оңға қарай қолданылатындықтан тапсырыс беріледі. Бұл матч болғанға дейін жалғасады.

Әрбір сүзгі элементі үш компоненттен тұрады - шарт, сәйкес келетін бөлік және ауыстыру бөлігі.

Шарт - хабарламаны бағалауды жалғастыру үшін элемент болуы керек қажетті күй.

Сәйкестендіретін бөлік - Бағаланатын хабарламаның үлгіге сәйкес келетін бөлігі.

Ауыстыру бөлігі - ертерек сәйкес келген хабарлама үшін ауыстыру мәндері көрсетілген бөлік.

Ішкі

Ішкі элементтер - бұл енгізу сүзгілеріне сілтеме жасайтын объектілер. Олар интерфейс бөлігінде толығымен қамтылған. Олар объектіні құру кезінде автоматты түрде жасалады.

Сыртқы

Сыртқы - бұл шығатын сүзгілерге сілтеме жасайтын объектілер. Олар композициялық сүзгілер моделінен тыс орналасқан, бірақ әлі де оның шеңберінде тұрған объектілерді жариялау үшін қолданылады. Мұндай нысандардың мысалы ретінде глобальды айнымалыларды айтуға болады.

SINA бағдарламалау тілі

SINA бағдарламалау тілі объектіге бағытталған бағдарламалау композициялық сүзгілердің объектілік моделінің ерекшеліктерін іске асыруға арналған тіл. Әрбір SINA бағдарламасы сыныптардың жиынтығы болып табылады, олардың әрқайсысы іске асыру және интерфейске бөлінуі мүмкін. SINA-ны алғашқы іске асыру үшін арналған Smalltalk және тек сол ортада жүгірді.[6]

Қолданбалар

Қарым-қатынастың дерексіз түрлері

Абстрактілі байланыс түріндегі объект объектілер арасындағы байланысты және өзара әрекеттесуді абстрактілейді. ACT-тің міндеттері - бұл қолданбаның барлық уақытында қайта қолдануға болатындығын жақсарту, жеке модульдерде енгізу туралы мәліметтерді жасыру және қабатты байланыс архитектураларын модельдеу күрделілігін төмендету.

Сарапшылар[ДДСҰ? ] кәдімгі объектіге бағытталған модельдер тым төмен деңгей деп санаймыз, өйткені екі объект арасындағы байланыс семантикасын басқа объектілерге оңай тарату мүмкін емес. Сондықтан қабаттағы әр жүйе өзінің іргелес қабаттарымен мәліметтер алмасатын қабатты жүйелік архитектураны модельдеу үшін қолданылатын жоғары деңгейлі тілдік механизм қажет болды. Мұрагерлік сияқты механизмдер тек абстракцияны объект деңгейінде ғана қамтамасыз етеді, бірақ объектілер арасындағы байланысты абстракциялауда сәтсіздікке ұшырайды.

Композициялық сүзгілер моделі объектілер арасындағы дерексіз байланыстарға қолданылды. Объект модулі қабылданған және жіберілген хабарламалармен не істеу керектігін анықтайтын кіріс және шығыс сүзгілерін енгізу арқылы кеңейтіледі.

ACT-тің маңызды артықшылықтарына мыналар жатады:

  • ACT-ді хабарламаларды ұстап алу және манипуляциялау үшін қолдануға болады, олардың екеуі де кіріс және шығыс сүзгілері арқылы жүзеге асырылады
  • ACTs өзара байланыс кодын (байланыс бөлшектерін) бөлек модульдерде жасыру арқылы бағдарламалардың күрделілігін төмендетеді. Бағдарламашылар бұл компоненттерді қайта пайдалану үшін объектіге бағытталған механизмдерді қолдана алады.[7]

Мәліметтер базасын біріктіру моделі

Композициялық сүзгілерді тұрақты динамикалық сияқты деректер базасының мүмкіндіктерін қосу үшін пайдалануға болады деректер құрылымдар, деректерді бөлісу, транзакциялар, көптеген көріністер және ан-қа ассоциативті қол жетімділік объект - бағдарланған тіл. Мұрагерлік пен өкілеттілік сияқты объектіге бағытталған негізгі механизмдерді композициялық сүзгілер де қамтамасыз етеді. Деректерді біріктіру моделінде деректерді біріктіру, қиылысу, алып тастау және таңдау сияқты мәліметтер базасы операциялары, мысалы, объектілікке бағытталған тетіктерді бөлшектемей, композициялық сүзгілерді қолдана отырып жасалады. абстракция, инкапсуляция, хабарлама жіберу және мұрагерлік.[8]

Басқа бағдарламалар

Композициялық сүзгілердің көптеген қосымшалары бар (соның ішінде SmallTalk және Java іске асыру). Қолданыстағы енгізулердің артықшылығы - тұжырымдамалық және іске асыру моделінің арасында ешқандай айырмашылық жоқ, бұл белгілі бір мүмкіндіктердің іске асырылуын түсінуді жеңілдетеді. Кемшілігі, дегенмен, бұл іске асырулар баяу және көп шығындар. Java-дағы бір бағдарлама, атап айтқанда ComposeJ, бұл мәселені компиляцияға бағытталған дерек көзін өзгерту тәсілін қолдану арқылы шешті.[9]

Сондай-ақ қараңыз

Сыртқы сілтемелер

Әдебиеттер тізімі

  1. ^ Аксит, Мехмет (1989-03-23). «Объектілі Синаның дизайны туралы». Твенте университеті зерттеу ақпараты.
  2. ^ Аксит, Мехмет. «Синайдағы деректерді жинау тетіктері / ст». ACM түймесін басыңыз. ISSN 0362-1340.
  3. ^ Аксит, Мехмет (1992). «Нысанға бағытталған тілдік-мәліметтер базасын интеграциялау моделі: композиция-сүзгілеу тәсілі». ECOOP '92 Объектіге бағытталған бағдарламалау бойынша Еуропалық конференция. Информатика пәнінен дәрістер. 615. Springer Verlag, Берлин. 372-395 бет. дои:10.1007 / BFb0053047. ISBN  3-540-55668-0.
  4. ^ Аксит, Мехмет (1992). «Бағдарламалық жасақтаманың объектілік-бағдарламалық жасақтамасындағы кедергілер». ACM SIGPLAN ескертулері. 27 (10): 341–358. дои:10.1145/141937.141965.
  5. ^ «Композиция сүзгілерінің нысаны». trese.cs.utwente.nl. Алынған 18 сәуір 2019.
  6. ^ Зиринг, Нил. «Бағдарламалау тілдерінің сөздігі». cgibin.erols.com. Алынған 2016-02-06.
  7. ^ Мехмет Аксит, Кен Вакита, Ян Бош, Лодевейк Бергманс және Акинори Йонезава, «Композициялық сүзгілерді қолдану арқылы объектілердің өзара әрекеттесуін абстракциялау», Твенте университеті, Токио университеті және Токио технологиялық институты
  8. ^ Мехмет Аксит, Лодевийк Бергманс және Синан Вурал, «Объектілі-тілдік мәліметтер базасын интеграциялау моделі: композиция-сүзгілеу тәсілі», Твент университетінің информатика кафедрасы
  9. ^ Йоханнес Корнелис Вичман, «ComposeJ - Java тіліндегі композициялық сүзгілерді жеңілдету үшін препроцессорды жасау», Твент университеті