Форум программистов, компьютерный форум, киберфорум
Visual Basic
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
0 / 0 / 1
Регистрация: 26.03.2007
Сообщений: 127

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

30.03.2007, 15:54. Показов 1605. Ответов 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
Ответ Создать тему
Новые блоги и статьи
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
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru