Декларативті бағдарламалау - Declarative programming

Жылы Информатика, декларативті бағдарламалау Бұл бағдарламалау парадигмасы - а логикасын білдіретін компьютерлік бағдарламалардың құрылымы мен элементтерін құру стилі есептеу оның сипаттамасынсыз басқару ағыны.[1]

Осы стильді қолданатын көптеген тілдер барынша азайтуға немесе жоюға тырысады жанама әсерлері сипаттау арқылы не Бағдарлама шарттарына сәйкес орындалуы керек проблемалық домен сипаттаудан гөрі Қалай оны бағдарламалау реті ретінде орындау тілдік примитивтер[2] ( Қалай тілдікі іске асыру ). Бұл керісінше императивті бағдарламалау жүзеге асырады алгоритмдер нақты қадамдарда.[3]

Декларативті бағдарламалау жиі қарастырады бағдарламалар а. теориялары ретінде формальды логика, және есептеу осы логикалық кеңістіктегі шегерімдер ретінде. Декларативті бағдарламалау жазуды едәуір жеңілдетуі мүмкін параллель бағдарламалар.[4]

Жалпы декларативті тілдерге мыналар жатады мәліметтер базасының сұраныстары (мысалы, SQL, XQuery ), тұрақты тіркестер, логикалық бағдарламалау, функционалды бағдарламалау, және конфигурацияны басқару жүйелер.

Анықтама

Декларативті бағдарламалау көбінесе бағдарламалаудың кез-келген стилі ретінде анықталады императивті. Бірқатар басқа жалпы анықтамалар оны императивті бағдарламалаумен салыстыра отырып анықтауға тырысады. Мысалға:

Бұл анықтамалар бір-біріне сәйкес келеді.

Декларативті бағдарламалау - бұл бағдарламалардың орындалуы қажет командалар мен қадамдардың тізімінсіз өздерінің қажетті нәтижелерін сипаттайтын бағдарламалаудың императивті емес стилі. Функционалды және логикалық бағдарламалау тілдерге декларативті бағдарламалау стилі тән. Жылы логикалық бағдарламалау тілдері, бағдарламалар логикалық тұжырымдардан тұрады, ал бағдарлама тұжырымдардың дәлелдерін іздеу арқылы орындалады.

Ішінде таза функционалды тіл, сияқты Хаскелл, барлық функциялар жанама әсерлері жоқ, және күй өзгерістері күйді түрлендіретін функциялар ретінде ғана ұсынылады, ол а түрінде айқын көрсетілген бірінші класс бағдарламадағы объект. Таза функционалды тілдер міндетті емес болғанымен, олар көбінесе функциялардың эффектісін бірнеше саты ретінде сипаттауға мүмкіндік береді. Сияқты басқа функционалды тілдер Лисп, OCaml және Эрланг, процедуралық және функционалды бағдарламалаудың араласуын қолдайды.

Сияқты кейбір логикалық бағдарламалау тілдері Пролог, және SQL сияқты мәліметтер қорының сұраныстары, негізінен декларативті болғанымен, сонымен қатар бағдарламалаудың процедуралық стилін қолдайды.

Субпарадигмалар

Декларативті бағдарламалау - бұл қолшатыр мерзімі бұған бірнеше танымал адамдар кіреді бағдарламалау парадигмалары.

Шектеу бағдарламалау

Шектеу бағдарламалау мақсатты шешімнің қасиеттерін көрсететін шектеулер түріндегі айнымалылар арасындағы қатынастарды айтады. Шектеу жиынтығы шешілді шешім әр шектеушіге сәйкес келетін етіп мән беру арқылы. Шектеу бағдарламалау көбінесе басқа парадигмаларды толықтырады: функционалды, логикалық немесе тіпті императивті бағдарламалау.

Доменге тән тілдер

Декларативтің белгілі мысалдары арнайы домендерге арналған тілдер (DSL) мыналарды қамтиды yacc талдаушы генератордың кіріс тілі, QML, Жасаңыз техникалық тілді құру, Қуыршақ конфигурацияны басқару тілі, тұрақты тіркестер, және ішкі бөлігі SQL (Мысалы, сұраныстарды таңдау). DSL-дің артықшылығы пайдалы, ал қажет болмауы керек Тюринг-аяқталған, бұл тілдің декларативті болуын жеңілдетеді.

Сияқты көптеген түзету тілдері HTML, MXML, XAML, XSLT немесе басқа пайдаланушы интерфейсін белгілеу тілдері көбінесе декларативті болып табылады. Мысалы, HTML тек веб-бетте не көрінетінін ғана сипаттайды - ол да көрсетпейді басқару ағыны бетті көрсету үшін немесе парақ мүмкін емес өзара әрекеттесу пайдаланушымен.

2013 жылғы жағдай бойынша кейбір бағдарламалық жүйелер[қайсы? ] дәстүрлі пайдаланушы интерфейсін белгілеу тілдерін (мысалы, HTML) декларативті белгілеумен үйлестіру, ол мәлімделген интерфейсті қолдау үшін серверлік жүйелердің не істеу керектігін анықтайды (бірақ қалай емес). Мұндай жүйелер, әдетте доменге тән XML аттар кеңістігі, SQL дерекқорының синтаксисінің абстракциясын немесе веб-қызметтерге параметрлік қоңырауларды қамтуы мүмкін өкілді мемлекеттік трансферт (REST) ​​және Сабын.[дәйексөз қажет ]

Функционалды бағдарламалау

Сияқты функционалды бағдарламалау тілдері Хаскелл, Схема, және ML функцияны қолдану арқылы өрнектерді бағалау. Байланысты, бірақ анағұрлым императивті парадигмасынан айырмашылығы Процедуралық бағдарламалау, функционалды бағдарламалау айқын реттілікке аз мән береді (мысалы, Схема, субэкспрессиялардың көптеген түрлерін бағалау тәртібі анықталмаған немесе анық емес[6]). Оның орнына есептеулер әр түрлі рекурсивті типтермен сипатталады жоғары ретті функция қолдану және құрамы, енгізу-шығару және деректерге анық сілтемелермен үнемді жұмыс істейді, және мемлекеттік мутация болдырмауға немесе мүмкіндігінше инкапсуляцияланған.

Гибридті тілдер

Мысалы, Makefiles тәуелділіктерді декларативті түрде көрсетеді,[7] сонымен қатар міндетті іс-қимылдар тізімін қосыңыз. Сол сияқты, yacc контекстсіз грамматиканы декларативті түрде анықтайды, бірақ хост тілінен алынған код үзінділерін қамтиды, әдетте бұл міндетті (мысалы, C ).

Логикалық бағдарламалау

Сияқты логикалық бағдарламалау тілдері Пролог мемлекет және сұраныс қатынастары. Ерекшеліктері Қалай бұл сұраулардың орындалуына және оның теоремалық дәлелдеуіне байланысты, бірақ әдетте қандай-да бір түрге ие болады біріктіру. Функционалды бағдарламалау сияқты көптеген логикалық бағдарламалау тілдері жанама әсерлерге жол береді, нәтижесінде қатаң декларативті емес.

Модельдеу

Физикалық жүйелердің модельдері немесе математикалық көріністері декларативті компьютерлік кодта жүзеге асырылуы мүмкін. Код мінез-құлық қатынастарын сипаттайтын («жариялайтын») бұйрық емес, бірнеше теңдеулерден тұрады. Модель осы формализмде көрсетілген кезде, компьютер шешім алгоритмін жақсы тұжырымдау үшін алгебралық манипуляцияларды орындай алады. Математикалық себептілік әдетте физикалық жүйенің шекарасында белгіленеді, ал жүйенің мінез-құлық сипаттамасы декларативті немесе акаузалды болып табылады. Декларативті модельдеу тілдері және қоршаған ортаға кіреді Analytica, Modelica және Ұқсас.[8]

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

Пайдаланылған әдебиеттер

  1. ^ Ллойд, Дж., Декларативті бағдарламалаудың практикалық артықшылықтары
  2. ^ «декларативті тіл». FOLDOC. 17 мамыр 2004 ж. Алынған 26 қаңтар 2020.
  3. ^ Себеста, Роберт (2016). Программалау тілдері туралы түсініктер. Бостон: Пирсон. ISBN  978-0-13-394302-3. OCLC  896687896.
  4. ^ «DAMP 2009: көп ядролы бағдарламалаудың декларативті аспектілері бойынша семинар». Cse.unsw.edu.au. 20 қаңтар 2009 ж. Алынған 15 тамыз 2013.
  5. ^ Чакраварти, Мануэль М. Т. (14 ақпан 1997). Декларациялық бағдарламаларды параллель түрде орындау туралы (Докторлық диссертация). Берлин техникалық университеті. Алынған 26 ақпан 2015. Бұл тұрғыда бағдарламалау тілін декларативті деп атаудың критерийі - бұл тіл мен декларативті семантиканың үлгіге немесе дәлелдеу теориясына (немесе екеуіне де) негізделуі үшін тіл мен математикалық логика арасында айқын, математикалық тұрғыдан бекітілген сәйкестіктің болуы. логика.
  6. ^ «Қайта қаралды7 Алгоритмдік тіл схемасы туралы есеп » (PDF). Жұмыс схемасы 1. Алынған 2020-12-05.
  7. ^ [1] Мұрағатталды 23 қазан 2007 ж Wayback Machine
  8. ^ «Декларативті модельдеу». Симулистика. Алынған 15 тамыз 2013.

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