MVEL - MVEL

MVEL
Mvel logo.png
ӘзірлеушілерМайк Брок және әр түрлі көмекшілер
Тұрақты шығарылым
2.3.0 / 15.06.2016 ж (2016-06-15)
Репозиторий Мұны Wikidata-да өңдеңіз
ЖазылғанJava
Операциялық жүйеКросс-платформа
ТүріӨрнек тілі (EL)
ЛицензияApache лицензиясы
Веб-сайтhttps://github.com/mvel/mvel

MVFLEX өрнек тілі (MVEL) - гибридті динамикалық / статикалық типтелген, ендірілетін Өрнек тілі және жұмыс уақыты үшін Java платформасы. Бастапқыда қосымшалар шеңберінің утилитасы ретінде басталған жоба қазір толықтай дербес әзірленді.

MVEL әдетте негізгі логиканы соңғы пайдаланушылар мен бағдарламашыларға конфигурация арқылы көрсету үшін қолданылады XML файлдар немесе аннотация. Ол сонымен қатар қарапайым талдау үшін қолданылуы мүмкін JavaBean өрнектер.

Жұмыс уақыты MVEL өрнектерін түсіндірмелі түрде немесе алдын-ала компиляция процесі арқылы жұмыс уақытын қолдай отырып орындауға мүмкіндік береді байт коды үстеме шығындарды жоюға арналған буын.

MVEL Java негізіндегі бағдарламалық жасақтаманы кеңейтуге арналғандықтан, синтаксистің көп бөлігін Java бағдарламалау тілінен кейбір кішігірім айырмашылықтармен және қосымша мүмкіндіктермен тікелей алады. Мысалы: класс және әдіс сілтемелерін тұрақты айнымалылар ретінде қарастыратын MVEL типтеу моделінің жанама әсері ретінде класс және функция сілтемелерін қолдануға болады (бірақ тек статикалық әдістер үшін).

     миллис = Жүйе.currentTimeMillis;     // миллис алу     уақыт = миллис();

MVEL сонымен қатар коллекцияларды а-да бүктемелер (немесе проекциялар) түрінде ұсынуға мүмкіндік береді Лисп - синтаксис сияқты.

    ата-ана = (ата-ана.аты жылы (балалар жылы қызметкерлер));

Сәлем әлемдік мысал

     Жүйе.шығу.println(«Сәлем Әлем!»);

MVEL Java аттары мен сыныптарына сүйенеді, бірақ аттар кеңістіктерін немесе кластарын жариялау мүмкіндігіне ие емес.

Quicksort мысалы

Міне, мысал Quicksort тілдің сценарий мүмкіндіктерін көрсететін MVEL 2.0-де жүзеге асырылған алгоритм.

импорт java.util. *;// квиксорттың негізгі алгоритмідеф жылдамдық(тізім) {    егер (тізім.өлшемі() <= 1) {         тізім;    }    басқа {         бұрылыс = тізім[0];         консоль(жылдамдық(($ жылы тізім егер $ < бұрылыс)), бұрылыс, жылдамдық(($ жылы тізім егер $ > бұрылыс)));    }}// тізімдерді біріктіру әдісін анықтаңыз.деф консоль(тізім1, бұрылыс, тізім2) {    concatList = жаңа ArrayList(тізім1);    concatList.қосу(бұрылыс);    concatList.addAll(тізім2);    concatList;}// сұрыптау үшін тізім жасаңызтізім = [5,2,4,1,18,10,15,1,0];// сұрыпта!жылдамдық(тізім);

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

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