|
0 / 0 / 0
Регистрация: 12.06.2017
Сообщений: 12
|
|||||||||||
Медленная работа regex25.07.2017, 10:16. Показов 2581. Ответов 11
Метки нет (Все метки)
Всем привет. Делаю небольшую программку для парсинга логов больших размеров. Столкнулся с такой проблемой, что выполнение программы медленное.
0
|
|||||||||||
| 25.07.2017, 10:16 | |
|
Ответы с готовыми решениями:
11
Boost Regex, работа с указателями Regex - работа с файлом Aser v5 i7 u - очень медленная загрузка системы и такая же медленная работа приложений |
|
2393 / 1913 / 763
Регистрация: 27.07.2012
Сообщений: 5,557
|
|
| 25.07.2017, 11:43 | |
|
Ну разве что по классическим заповедям писать
++i. Ну и строку в функцию по ссылке передавать.
0
|
|
|
93 / 69 / 22
Регистрация: 17.10.2011
Сообщений: 235
|
|
| 25.07.2017, 12:03 | |
|
можно делать все сравнения за один проход, и хранить все частичные совпадения до текущей позиции, для этого нужны только индекс начала частичного совпадения и индекс текущей позиции
0
|
|
|
зомбяк
1585 / 1219 / 345
Регистрация: 14.05.2017
Сообщений: 3,940
|
||||||||||||||||
| 25.07.2017, 12:55 | ||||||||||||||||
|
И ещё
Потому что в
0
|
||||||||||||||||
|
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
|
|||||||
| 25.07.2017, 19:34 | |||||||
|
компилять релиз в режиме оптимизации по скорости, а не дебаг с 100500 всевозможных проверок. 2. если это не поможет, тогда уже можно начинать потрошить код. всякие такие места: количество элементов можно закэшировать. это может помочь компилятору оптимизировать цикл а не сравнивать каждый раз строки emplace_backпочитайте на досуге: https://habrahabr.ru/post/246257/
0
|
|||||||
|
0 / 0 / 0
Регистрация: 12.06.2017
Сообщений: 12
|
||||||||
| 26.07.2017, 09:19 [ТС] | ||||||||
|
в ip_mass может закидываться не только ip, то что было задано regexp`ом, то и идёт в массив (Изначально была задача только ip парсить, а потом задача поменялась). Добавлено через 17 минут Применил все советы, что мне дали, но в итоге время выполнения изменилось на 100 ms. В конце концов, самым лагающим куском кода так и остался цикл for(sregex_iterator i = rBeg;i!=rEnd;++i). даже если закомментить функцию внутри него, то время выполнения будет меньше на 157ms. Делал ещё вариант:
Чем быстрым можно заменить пробег по итератору, я не могу придумать.
0
|
||||||||
|
зомбяк
1585 / 1219 / 345
Регистрация: 14.05.2017
Сообщений: 3,940
|
|
| 26.07.2017, 14:47 | |
|
Вероятно дело в том, что регулярное выражение интерпретируется, а не компилируется. Для того, чтоб оно использовалось в скопилированном виде, нужна библиотека наподобие http://blablacode.ru/programmirovanie/63 , но в этом случае регурлярное выражение должно быть задано дефайном, а не передаваться через argv[2] .
Ну а чтобы программа компилировала свои же куски во время выполнения - такое и антивирус может заблокировать, и компилятор пришлось бы вовнутрь встраивать. В общем для скорости скорее всего придётся отказаться от ввода выражений в командной строке.
0
|
|
|
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
|
|||
| 26.07.2017, 20:29 | |||
|
2) Другой движок.
0
|
|||
|
1550 / 877 / 179
Регистрация: 05.12.2015
Сообщений: 2,555
|
||
| 27.07.2017, 02:30 | ||
|
0
|
||
|
зомбяк
1585 / 1219 / 345
Регистрация: 14.05.2017
Сообщений: 3,940
|
||
| 27.07.2017, 02:41 | ||
|
avgoor, вероятно речь о 31 секунде. Если прикинуть по
0
|
||
|
1550 / 877 / 179
Регистрация: 05.12.2015
Сообщений: 2,555
|
|
| 27.07.2017, 02:54 | |
|
TRam_, Да нет. Судя по тексту, где речь идет о семи секундах и "выигрыш в пару ms - как капля в море".
Скорее всего, намерял погоду на марсе, или мерял отдельно, отключив обработку, и оптимизатор просто выпилил КЕМ чтение файла.
0
|
|
|
0 / 0 / 0
Регистрация: 12.06.2017
Сообщений: 12
|
|
| 28.07.2017, 08:30 [ТС] | |
|
Всё, проблема решена. Убрал флаг -pg при компиляции и всё отрабатывает за 5s.
0
|
|
| 28.07.2017, 08:30 | |
|
Помогаю со студенческими работами здесь
12
Медленная работа с БД медленная работа Медленная работа 1С Медленная работа с БД Медленная работа в 1с по сети Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод
Ниже машинный перевод статьи The Thinkpad X220 Tablet is the best budget school laptop period .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы,. . .
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|