Оптимизация использования ЦП при сопоставлении регулярных выражений JavaJAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Оптимизация использования ЦП при сопоставлении регулярных выражений Java

Сообщение Anonymous »

Я столкнулся с проблемой производительности, связанной с сопоставлением регулярных выражений в моем проекте Java, что привело к высокой загрузке ЦП. Несмотря на мои попытки оптимизации регулярных выражений, я все еще испытываю проблемы с производительностью, особенно когда несколько потоков одновременно вызывают код.
Например, при вызове метода, который одновременно выполняет сопоставление регулярных выражений 100 раз, загрузка ЦП на короткое время возрастает до 90%.
Вот упрощенный пример моего кода:

Код: Выделить всё

String BUY_PATTERN =".*\\b(purchase)\\b.*";

private static boolean isMatchPattern(String pattern, String text) {
return text.matches(BUY_PATTERN);
}
Я хотел бы уменьшить загрузку ЦП при сопоставлении регулярных выражений. Можете ли вы предоставить предложения по более эффективным шаблонам регулярных выражений, которые обеспечивают ту же функциональность?
Кроме того, я наткнулся на статью (ссылка предоставлена), в которой обсуждается влияние поиска с возвратом на производительность, но мне сложно переписать регулярное выражение, чтобы свести к минимуму возврат с возвратом.
Спасибо за вашу помощь!

Подробнее здесь: https://stackoverflow.com/questions/762 ... x-matching
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»