Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.87/15: Рейтинг темы: голосов - 15, средняя оценка - 4.87
0 / 0 / 2
Регистрация: 24.06.2012
Сообщений: 112

В каком STL-контейнере лучше хранить объекты?

14.09.2016, 19:31. Показов 3777. Ответов 26

Студворк — интернет-сервис помощи студентам
Есть класс, реализующий адреса
C++
1
2
3
class address {
...
}
Поискал в сети увидел 3 варианта хранения объектов : массив(array), вектор(vectro), список(list).
Массив нельзя создать неизвестного размера, нужно сразу выделять память, например
C++
1
2
address *ad_array[100]; //работает
address *ad_array[]; //ошибка
Такой вариант не подходит, неизвестно сколько будет объектов.
Вектора, все бы ничего, но удалять говорят тут не правильно их, хотя и можно так:
C++
1
2
3
vector<address> ad_vector();
ad_vector.push_back(address());
v.erase( remove( ad_vector.begin(), ad_vector.end()), ad_vector.end() );
С list еще ничего не делал. Как правильнее поступать с объектами?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.09.2016, 19:31
Ответы с готовыми решениями:

Как хранить объекты разных классов в одном контейнере
Здравствуйте! Хочу реализовать хранение разных классов(базовый и наследник) в одном контейнере. На форуме искал, но, к сожалению, не...

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

В каком формате лучше хранить образ ОС?
В .dmg или в .iso лучше? Если сохраняю

26
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
15.09.2016, 15:00
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от gng Посмотреть сообщение
После выделения этот адрес уже в адресносном пространстве программы и не нужно ничего спрашивать у системы.
Есть, конечно, нюансы. На многих системах выделение будет витруальным и первый запрос на чтение/запись будет действительно выполняться долго. Но такое бывает не всегда.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#include <vector>
#include <ctime>
 
int main(int argc, char* argv[] )
{
    const size_t size = 10000;
 
    size_t start_time =  clock();
 
    std::vector<int> array_(size);
    //int array_[size];
 
    for (size_t i = 0; i < size; i++)
        for (size_t j = 0; j < size; j++)
               array_[j] = j;
 
    size_t end_time = clock();
    size_t search_time = end_time - start_time;
 
    search_time = 0;
    start_time = clock();
 
    for (size_t i = 0; i < size; i++)
        for (size_t j = 0; j < size; j++)
               array_[j] = j;
 
    end_time = clock();
    search_time = end_time - start_time;
 
    return 0;
}
0
Эксперт С++
 Аватар для hoggy
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
15.09.2016, 15:03
Цитата Сообщение от _stanislav Посмотреть сообщение
vs 13 у меня не получилось стек увеличить.
жизнь - боль и страдание.

попробуйте использовать std::vector,
и приятных вам реалоков.
0
2549 / 1208 / 358
Регистрация: 30.11.2013
Сообщений: 3,826
15.09.2016, 15:11
Цитата Сообщение от hoggy Посмотреть сообщение
жизнь - боль и страдание.
0
Игогошка!
 Аватар для ct0r
1801 / 708 / 44
Регистрация: 19.08.2012
Сообщений: 1,367
15.09.2016, 15:24
Если считаем, что размер фиксирован, то по производительности вектор и массив не отличаются.

Однако в некоторых случаях теоретически массив будет быстрее:
1) Первое выделение памяти - массиву надо просто сдвинуть вершину стека, вектору надо делать системный вызов, бороться в возможной фрагментацией и тд и тп.
2) Если у нас много разных выделений памяти в разных потоках. Куча делится между ними, стоим внутри new из-за синхронизации. (Подразумевается, что мы хотим юзать дефолтные аллокаторы.) Стек - у каждого свой, будет все без узких мест.
3) У нас вокруг переменной вектора/массива еще есть другие данные, которые мы часто юзаем. Данные массива рядом с ними, данные вектора - нет. Может как-то влиять на кэш.

_stanislav, выруби дебаг-то, собери нормальный релиз с оптимизацией, а то небось со всеми ассертами и отладочной инфой для вектора смотришь.
0
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
15.09.2016, 15:51
Цитата Сообщение от ct0r Посмотреть сообщение
выруби дебаг-то, собери нормальный релиз с оптимизацией, а то небось со всеми ассертами и отладочной инфой для вектора смотришь
Да, массив чуть быстрее, но не существенно.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#include <iostream>
#include <vector>
#include <ctime>
 
int main(int argc, char* argv[] )
{
    const size_t size = 10000;
    size_t start_time, end_time, search_time;
 
    start_time =  clock();
 
    std::vector<int> vector(size);
 
    for (size_t i = 0; i < size; i++)
        for (size_t j = 0; j < size; j++)
               vector[j] = j;
 
    end_time = clock();
    search_time = end_time - start_time;
 
    std::cout << "vector1: " << search_time
        <<std::endl;
 
    search_time = 0;
    start_time = clock();
 
    for (size_t i = 0; i < size; i++)
        for (size_t j = 0; j < size; j++)
               vector[j] = j;
 
    end_time = clock();
    search_time = end_time - start_time;
 
    std::cout << "vector2: " << search_time
        <<std::endl;
 
    start_time =  clock();
    
    int array_[size];
 
    for (size_t i = 0; i < size; i++)
        for (size_t j = 0; j < size; j++)
               array_[j] = j;
 
    end_time = clock();
    search_time = end_time - start_time;
 
    std::cout << "array1: " << search_time
        <<std::endl;
 
    start_time = clock();
 
    for (size_t i = 0; i < size; i++)
        for (size_t j = 0; j < size; j++)
               array_[j] = j;
 
    end_time = clock();
    search_time = end_time - start_time;
 
    std::cout << "array2: " << search_time
        <<std::endl;
 
    return 0;
}
Миниатюры
В каком STL-контейнере лучше хранить объекты?  
0
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
15.09.2016, 16:11
поменял местами вектор и массив, то есть массив первым проверял, массив стал отрабатывать чуть медленней. первый вызов.
0
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
15.09.2016, 16:14
___
Миниатюры
В каком STL-контейнере лучше хранить объекты?  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.09.2016, 16:14
Помогаю со студенческими работами здесь

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

ПС Сервисный центр. В каком виде лучше хранить информацию
Здравствуйте. Мы изучаем в колледже C#. Задали курсовую работу. Я выбрал работу &quot;сервисный центр&quot;, т.к сам занимаюсь ремонтом...

Автодополнение функций: в каком объекте лучше хранить их спосок
День добрый, Пишу свой редактор javascript с базой данных(пока Access) интересуют варианты реализации 2х полезных функций: 1....

Где и в каком виде лучше всего хранить данные, загруженные из БД
Здравствуйте. При загрузке страницы, происходит обращение к бд, таким образом я получаю некоторую информацию из БД. Где лучше всего...

В каком формате лучше хранить текст для корректной обработки в дальнейшем?
есть строка #1#0#31#2 в каком формате ее хранить? что бы потом корректно прочитать Добавлено через 5 минут сейчас делаю так ...


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

Или воспользуйтесь поиском по форуму:
27
Ответ Создать тему
Новые блоги и статьи
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений. . . .
21 мат мед. Планы на развитие модели здравоСохранения
anaschu 01.06.2026
AnyLogic: план развития симуляционной модели рабочего коллектива — динамический абсентеизм, реальные данные, три сценария сравнения Продолжаю серию постов о дискретно-событийной модели рабочего. . .
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
Модель здравосохранения 18. Чем здоровее работник, тем быстрее выгорает
anaschu 24.05.2026
Имитационная модель корпоративного здравоохранения: что показывает математика Сегодня в модели рабочего коллектива на AnyLogic появились три новые механики — выгорание через накопленную усталость,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru