Jump to content

RE2 (программное обеспечение)

РЕ2
Оригинальный автор(ы) Google
Первоначальный выпуск 11 марта 2010 г .; 14 лет назад ( 11.03.2010 ) [1]
Стабильная версия
01.04.2021 / 1 апреля 2021 г .; 3 года назад ( 01.04.2021 ) [2]
Репозиторий
Написано в С++
Операционная система Кросс-платформенный
Тип сопоставления шаблонов Библиотека
Лицензия БСД
Веб-сайт github /Google /re2 Отредактируйте это в Викиданных

RE2 — это программная библиотека , которая реализует механизм регулярных выражений через конечные автоматы с использованием теории автоматов , в отличие от почти всех других библиотек регулярных выражений , которые используют с обратным отслеживанием реализации . Он предоставляет интерфейс C++ .

RE2 был реализован и использован Google . «на лету», Библиотека использует детерминированный алгоритм конечного автомата основанный на Кена Томпсона Plan 9 grep . [3]

Сравнение с PCRE

[ редактировать ]

RE2 обычно сравним по производительности с Perl-совместимыми регулярными выражениями (PCRE). Для некоторых операторов регулярных выражений, таких как | (оператор чередования или логической дизъюнкции ) превышает PCRE. С другой стороны, в отличие от PCRE, который поддерживает такие функции, как обратные ссылки , RE2 способен распознавать только обычные языки благодаря своей конструкции с использованием Thompson DFA. [3] алгоритм. Он также немного медленнее, чем PCRE, для операций захвата в скобках.

PCRE может использовать большой рекурсивный стек с соответствующим высоким использованием памяти, что приводит к экспоненциальному времени выполнения определенных шаблонов. Напротив, RE2 использует фиксированный размер стека и гарантирует, что время его выполнения увеличивается линейно (а не экспоненциально) с размером входных данных. Максимальный объем памяти, выделенный с помощью RE2, можно настроить.

RE2 имеет немного меньший набор функций, чем PCRE, но имеет очень предсказуемое время выполнения и максимальное выделение памяти. Это может сделать его более подходящим для использования в серверных приложениях, которые требуют ограничений по использованию памяти и времени вычислений. PCRE, с другой стороны, поддерживает больше функций, таких как обходы, обратные ссылки и рекурсия , но имеет непредсказуемое время выполнения и использование памяти, которое может неограниченно расти.

Принятие

[ редактировать ]

Использование в продуктах Google

[ редактировать ]

RE2 используется такими Google продуктами , как Gmail , Google Documents и Google Sheets . [4] См. документацию по синтаксису на GitHub: Синтаксис RE2 .

В Google Sheets он используется в функциях RegexMatch() , RegexReplace() , RegexExtract() и функции поиска и замены . RegexExtract() не использует группировку .

[ редактировать ]

Алгоритм RE2 был переписан на Rust как пакет «regex». CloudFlare Брандмауэр веб-приложений использует этот пакет, поскольку алгоритм RE2 невосприимчив к ReDoS . [5]

Расс Кокс также написал RE1, более раннее регулярное выражение, основанное на интерпретаторе байт-кода. [6] OpenResty использует форк RE1 под названием «sregex». [7]

См. также

[ редактировать ]
  1. ^ Кокс, Расс (11 марта 2010 г.). «RE2: принципиальный подход к сопоставлению регулярных выражений» . Блог Google с открытым исходным кодом . Проверено 29 мая 2020 г.
  2. ^ «Выпуски» . Гитхаб . Проверено 3 мая 2021 г.
  3. ^ Jump up to: а б Кокс, Расс. «Сопоставление регулярных выражений в дикой природе» . swtch.com .
  4. ^ «Найти и использовать найти и заменить» . Проверено 24 марта 2020 г.
  5. ^ «Ускорение WAF на 40 %» . Блог Cloudflare . 1 июля 2020 г.
  6. ^ «Сопоставление регулярных выражений: подход виртуальной машины» . swtch.com .
  7. ^ «openresty/sregex: Perl-совместимый механизм регулярных выражений на основе NFA/DFA без обратного отслеживания, сопоставляющий большие потоки данных» . OpenResty. 6 февраля 2024 г.
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: ba9cb0e1d0d9806d2199073998b8638d__1719005100
URL1:https://arc.ask3.ru/arc/aa/ba/8d/ba9cb0e1d0d9806d2199073998b8638d.html
Заголовок, (Title) документа по адресу, URL1:
RE2 (software) - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)