0 / 0 / 1
Регистрация: 26.03.2007
Сообщений: 127

Аналог InStr, но который работал бы быстрее с большим объемом данных

30.03.2007, 15:54. Показов 1639. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть ли аналог InStr, но который работал бы быстрее с большим объемом данных?

P.S. надо в цикле (от 1 до 100 000) искать в String переменной строку ( 5-6 символов )
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.03.2007, 15:54
Ответы с готовыми решениями:

Почему код, написанный на С++, в разы быстрее работает с большим объемом памяти, чем с маленьким?
Привет! Понадобилось мне сравнить скорость работы идентичных алгоритмов на Fortran и C++. Алгоритм - перемножение матриц. Решил...

Работа с большим объемом данных
Имеется загруженное изоображение с помощью opencv. Задача: вывести цвета изображения с из колличеством. Цвет задаю структурой, хранящей...

Работа с большим объемом данных
Коллеги, подскажите по такому вопросу. Есть выборка, несколько миллионов записей. Каким образом с ней правильно работать в Python?...

4
VladK
01.04.2007, 14:07
Try this:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
Private Sub Command1_Click()
   Dim i
   
   Debug.Print Time
   For i = 1 To 10000000
 If InStrB(1,'ABCD','C', vbBinaryCompare)>0  Then
 
 End If
   Next i
   Debug.Print Time
End Sub
It took 5 seconds vs. 65 seconds for
InStr(1,'ABCD','C', vbTextCompare).

It appears that this function does the same job as Instr (they are = 0 or <> 0 for the same conditions). The only difference is the way how they work.

The InStrB function is used with byte data contained in a string. Instead of returning the character position of the first occurrence of one string within another, InStrB returns the byte position.

Thank you
Vlad
0 / 0 / 0
Регистрация: 01.03.2007
Сообщений: 10
07.04.2007, 18:53
Не советую пользоваться предыдущим примером без доработки...
InStrB ищет байтовую строку. А символы в VB'шном String - двухбайтовые.
Здесь надо ещё полученный результат на чётность проверять - это первое.
А потом, если позиция оказалась нечётной, искать дальше, начиная со следующего символа.
И наконец, в том примере сравнение производительности некорректно - vbBinaryCompare
по определению быстрее vbTextCompare.
0
VladK
07.04.2007, 19:13
Спасибо за дополнение. Я подозревал нечто подобное. Перед тем как послать пример я его проверил на разных строках и получил одно и тоже. Буду благодарен за контр пример.
Кстати, VB HELP не упоминает о возможной разнице в результатах.
Пример же мой считаю вполне корректным, так как человека интересует конечная производительность на обычных текстовых строках. Кроме того, байтовый поиск в Str не столь быстр как в StrB.

Vlad
0 / 0 / 0
Регистрация: 01.03.2007
Сообщений: 10
07.04.2007, 22:27
To Vlad:
Твой пример будет работать в подавляющем большинстве случаев.
Но возможна ситуация, когда он не сработает.
Я, правда, не знаю, может ли это произойти при работе с текстовыми строками - проверять лень ;-))
Тем не менее, каждый символ в VB String - два байта. Может случиться и так, что найденая
подстрока (InStrB строку интерпретирует как последовательность байт) будет начинаться со 'второй половины' символа.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.04.2007, 22:27
Помогаю со студенческими работами здесь

Работа с большим объёмом данных
Приветствую всех! На днях столкнулся с такой проблемой: необходимо отправить на сервер файл большого размера (для теста взял 37 МБ) из...

Работа с большим объемом данных
Всем привет! Работа с большим объемом данных заставляет задуматься над всевозможными способами оптимизации алгоритма. Возьмем простой...

работа с большим объемом данных
большим я называю от 300000Rx50C судя по информации из диспетчера задач происходит накопление памяти что приводит к постепенному...

Работа с большим объемом данных
Всем привет! Всегда создавал коллекцию List&lt;List&lt;xxx&gt;&gt;, заносил в нее данные из txt файла, а потом с этой коллекцией уже работаю. Так я...

Оптимизация запроса с большим объемом данных
Добрый день. Прошу помощи у профессионалов по ускорению запроса для Mysql Есть таблица email_subscribe с набором значений: id ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru