С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/13: Рейтинг темы: голосов - 13, средняя оценка - 4.54
0 / 0 / 0
Регистрация: 05.02.2016
Сообщений: 6

Хранение большого количества однотипных данных

05.02.2016, 10:22. Показов 2683. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день.
Подскажите, каким образом хранить данные для программы? Например, у меня имеется 1000 - 300 000 строковых данных, которые мне нужно сравнивать с определёнными вводимыми значениями каждый раз при вызове программы. Где их хранить? Массив, контейнер или отдельный файл (другие варианты, например, таблица БД)? Насколько будет различаться производительность?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.02.2016, 10:22
Ответы с готовыми решениями:

Хранение большого количества бинарных данных
Возник вопрос связаный с хранением данных: Мне нужно сохранять массивы бинарных данных (каждый массив - 4096 элементов по 1 байту) Если...

Хранение большого (15000) количества строк в строковом массиве
Здравствуйте! Мне нужно создать генератор слов. Я решил пойти путем словаря + генератор псевдослучайных чисел. Файл сделал вложением,...

Хранение большого количества данных (5 миллиардов пар чисел)
Всем привет! У меня возникла следующая проблема. Необходимо хранить в программе последовательность примерно из 5 миллиардов пар чисел,...

13
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,170
Записей в блоге: 10
05.02.2016, 10:54
Как часто происходит сравнивание?
0
14 / 14 / 16
Регистрация: 26.01.2015
Сообщений: 213
05.02.2016, 10:57
Ну из того, что я знаю, это массив - совокупность однотипных элементов.
0
0 / 0 / 0
Регистрация: 05.02.2016
Сообщений: 6
05.02.2016, 11:05  [ТС]
Как часто происходит сравнивание?
От 1 до, возможно, нескольких сотен.
0
 Аватар для ThePlague
104 / 104 / 99
Регистрация: 30.06.2015
Сообщений: 272
05.02.2016, 11:12
emission,
которые мне нужно сравнивать с определёнными вводимыми значениями каждый раз при вызове программы.
тогда влюбом случае вне программы...думаю что просто в файле будет быстрее чем выдерать из БД.
считываешь файл записываешь в лист или вектор и сравниваешь...
1
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,170
Записей в блоге: 10
05.02.2016, 11:15
Цитата Сообщение от emission Посмотреть сообщение
От 1 до, возможно, нескольких сотен.
Интересная частота...
Если не прибегать к хитростям, то просто создай массив указателей на строки.
0
 Аватар для ThePlague
104 / 104 / 99
Регистрация: 30.06.2015
Сообщений: 272
05.02.2016, 11:17
castaway, а хранение строковых данных после завершения программы?
0
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,170
Записей в блоге: 10
05.02.2016, 11:18
Цитата Сообщение от emission Посмотреть сообщение
которые мне нужно сравнивать с определёнными вводимыми значениями каждый раз при вызове программы.
Давай разберёмся. Один вызов программы - одно сравнение?

Добавлено через 1 минуту
Цитата Сообщение от ThePlague Посмотреть сообщение
castaway, а хранение строковых данных после завершения программы?
Поясните вопрос.
0
 Аватар для ThePlague
104 / 104 / 99
Регистрация: 30.06.2015
Сообщений: 272
05.02.2016, 11:21
castaway, просто как я понял emissionа, ему нужно гдето хранить от 1к до 300к строковых переменых...и каждый раз сравнивать их с входящими данными при вызове программы...(поправте если не так понял)...

или отдельный файл (другие варианты, например, таблица БД)? Насколько будет различаться производительность?
вот тут
0
0 / 0 / 0
Регистрация: 05.02.2016
Сообщений: 6
05.02.2016, 11:31  [ТС]
Цитата Сообщение от castaway Посмотреть сообщение
Давай разберёмся. Один вызов программы - одно сравнение?
Вызов программы - обязательно одно сравнение, остальные - в вызванной первым сравнением.
0
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,170
Записей в блоге: 10
05.02.2016, 11:33
emission, в данной постановке нет смысла в БД. И разницы между массивом, вектором или списком тоже нет. Пробуй. Замеряй время.

Цитата Сообщение от ThePlague Посмотреть сообщение
тогда влюбом случае вне программы...думаю что просто в файле будет быстрее чем выдерать из БД.
Быстрее будет прочитать весь файл за раз.
0
0 / 0 / 0
Регистрация: 05.02.2016
Сообщений: 6
05.02.2016, 12:56  [ТС]
Т.е., из всего вышеописанного получается, что оптимальный вариант - хранить массив строк в отдельном, подключённом к программе, файле? (в данном случае)
0
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,170
Записей в блоге: 10
05.02.2016, 13:05
Цитата Сообщение от emission Посмотреть сообщение
Т.е., из всего вышеописанного получается, что оптимальный вариант - хранить массив строк в отдельном, подключённом к программе, файле?
Загрузи весь файл за раз, или спроецируй, если это позволяет ОС.
1
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
05.02.2016, 15:42
Имхо, строки должны быть отсортированы и искаться чем-то вроде деления пополам.

Добавлено через 2 минуты
Или делать что-то вроде кэша.
А место хранения - дело десятое. Память позволит - хранить в памяти. Не позволит - в массиве.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.02.2016, 15:42
Помогаю со студенческими работами здесь

Хранение большого количества файлов
Есть свой видео-хостинг типа ютуба, и вот такой вопрос возник. Как мне организовать хранение файлов в файловой системе так, чтоб потом...

Хранение и использование большого количества изображений
Всем привет! Подскажите способ хранения большого количества изображений, чтобы можно было эти изображения удобно использовать. Смотрел...

Хранение большого количества настроек - нужна подсказка
Пишу программу, которая требует хранения множества настроек. Я их разделил на несколько типов: 1) размер и положение окна, размер...

Хранение большого количества файлов и быстрый доступ к ним
мне надо хранить загружаемые файлы чтобы доступ к любому файлу был очень быстрым. т.к. пути к файлом и список файлов пользователя хранится...

Оптимизировать хранение данных для однотипных товаров
Нужно организовать бд для товаров, проблема следующая: -есть товар и у него есть размеры и цена в зависимости от размера и материала; ...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
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/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru