|
19 / 11 / 0
Регистрация: 02.09.2010
Сообщений: 235
|
||
ВопросЫ по функциям для работы со строками с++15.02.2011, 20:06. Показов 9862. Ответов 18
Метки нет (Все метки)
Вот я нашел большинство (если не все) стандартные функции C++ для работы со строками:
Что касается остальных функций - непонятно, в интернете приведены какраз самописные альтернативы через цикл for, но про то, что в итоге они окажутся медленнее стандартных - не предупреждается. Если вреальности стандартные функции реализованы через for - получается когда мне нужно поочереди провести операцию над, к примеру, сотней строк - получится быстрее самому через цикл сделать, т.к. в этому случае не будет происходить каждый раз выделение памяти под счетчик в цикле, для всех копирований я могу один раз определить счетчик (переменную int i) и поочереди использовать его в циклах. Вопрос, что быстрее - 100 раз использовать strcat или 100 раз через цикл for побайтно добавлять одну строку к другой, используя на все 100 операций один раз введенный счетчик int i? И второй вопрос, как работают стандартные функции, по принципу memcpy или через цикл? Надеюсь всё правильно написал с точки зрения терминологии ![]() Спасибо за любые предположения
0
|
||
| 15.02.2011, 20:06 | |
|
Ответы с готовыми решениями:
18
Теоретические вопросы по функциям в языке С и C++ Вопросы по созданию класса для работы сo строками
|
|
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
|
|
| 15.02.2011, 20:13 | |
|
Damaks, memset
Как видите, memset работает через тот же самый цикл.
0
|
|
|
19 / 11 / 0
Регистрация: 02.09.2010
Сообщений: 235
|
|
| 15.02.2011, 20:15 [ТС] | |
|
Пардон, я где-то ошибся, щас поправлю
Я имел ввиду memcpy , поправил
0
|
|
|
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
|
|
| 15.02.2011, 20:17 | |
|
И кстати, она ничего из массива в массив не копирует, она просто заполняет первые n байт переданного ей массива заданными значениями.
0
|
|
|
19 / 11 / 0
Регистрация: 02.09.2010
Сообщений: 235
|
||
| 15.02.2011, 20:24 [ТС] | ||
|
Ещё нашел memcmp, вроде как делает тоже самое, что и strcmp
На том сайте написано:
silent_1991 а насчёт других функций, например strcat - она как работает?
0
|
||
|
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
|
|
| 15.02.2011, 20:29 | |
|
2
|
|
|
19 / 11 / 0
Регистрация: 02.09.2010
Сообщений: 235
|
|
| 15.02.2011, 21:35 [ТС] | |
|
Посмотрел, получается вывод такой - лучше побайтно обрабатывать строки в цикле, нежели использовать стандартные, "оптимизированные" функции. Так?
Некоторое время назад меня убеждали в обратном...
0
|
|
|
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
|
|
| 15.02.2011, 21:37 | |
|
Damaks, лучше не изобретать велосипед.
0
|
|
|
19 / 11 / 0
Регистрация: 02.09.2010
Сообщений: 235
|
|
| 15.02.2011, 21:43 [ТС] | |
|
Почему? Если выходит что работает быстрее!
И яб не назвал это велосипедом. В особенности если нужно обработать тысячи строк со сложной структурой.
0
|
|
|
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
|
|
| 15.02.2011, 21:44 | |
|
Damaks, тогда используйте ассемблерные вставки или вообще на асме сразу пишите - ещё быстрее работает.
0
|
|
|
19 / 11 / 0
Регистрация: 02.09.2010
Сообщений: 235
|
|
| 15.02.2011, 21:45 [ТС] | |
|
Нее, обойдусь с++
0
|
|
|
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
|
|
| 15.02.2011, 21:48 | |
|
Damaks, ну вот, пишите на плюсах и говорите о какой-то производительности. Если вы будете использовать, скажем, std::vector и алгоритмы, а десятью строчками ниже ради выигрыша в производительности будете писать цикл вместо использования такого же, уже написанного до вас, цикла - ну как это выглядит?
0
|
|
|
17 / 17 / 0
Регистрация: 16.08.2010
Сообщений: 252
|
|
| 15.02.2011, 21:54 | |
|
Правильнее использовать готовые функцииии, которые оптимизированы под конкретную платформу strncmp, strchr и т.п. а не через циклы. Многие компиляторы сейчас имеют встроенные операции для подобных функций, которые оптимизированы для конкретного процессора (выбирает компилятор в зависимости от опций компиляции)
0
|
|
|
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
|
|
| 15.02.2011, 21:55 | |
|
Так компилятор и так код оптимизирует как может.
А мы же всё-таки не в век 386-х живём, чтобы так за производительностью гнаться.
0
|
|
|
19 / 11 / 0
Регистрация: 02.09.2010
Сообщений: 235
|
|
| 15.02.2011, 22:05 [ТС] | |
|
Боюсь в моём случае это существенно. Но я толком с++ не освоил, чтобы ассемблер использовать.
Так я не понял, всётаки получается что функции будут быстрее?
0
|
|
|
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
|
|
| 15.02.2011, 22:08 | |
|
Damaks, в данном случае нет, не получается. Помимо самого цикла будут ещё затраты на вызов функции, копирование параметров и возврат значения.
0
|
|
|
0 / 0 / 0
Регистрация: 16.01.2012
Сообщений: 13
|
|
| 10.02.2012, 01:36 | |
|
Как сделать поиск в строке.?
0
|
|
|
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
|
|
| 10.02.2012, 11:28 | |
|
V-Denim, strstr
0
|
|
|
|
|
| 10.02.2012, 18:03 | |
|
по поводу memcpy() - это самая быстрая реализация пересылки байт (слов) из одного участка памяти в другой.
Самая быстрая потому, что она реализована через ассемблерную команду movsb(movsw), которая копирует байты(слова) адресуемые регистром esi в память, на которую указывает edi. Т.е. в реализации memcpy нет ни каких циклов, переходов и т.д.
0
|
|
| 10.02.2012, 18:03 | |
|
Помогаю со студенческими работами здесь
19
Контрольные вопросы по процедурам и функциям Общие вопросы для реальной работы Алгоритм для работы со строками Класс для работы со строками Разработка ПО для работы со строками Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/
O1rJuneU_ls
https:/ / vkvideo. ru/ video-115721503_456239114
|
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ВВЕДЕНИЕ
Введу сокращения:
аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
|
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi
ветка по-частям.
коммит Create переделка под биомассу. txt
вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
|
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ *
Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях.
Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её.
Последовательность действий:. . .
|
|
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
|
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение.
И на уровне агентов добавится между грибами или бактериями взаимодействий.
До того я пробовал подход через многомерные массивы,. . .
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|