Форум программистов, компьютерный форум CyberForum.ru

Вопрос по std::map - C++

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 56, средняя оценка - 4.95
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16946 / 5351 / 329
Регистрация: 30.03.2009
Сообщений: 14,389
Записей в блоге: 26
08.05.2010, 20:13     Вопрос по std::map #1
В качестве хэш-таблицы для строк (AnsiString) я использовал std::map. От таблицы мне нужно было ещё и такое свойство: я хотел иметь информацию о том, присутсвует данный ключ в таблице или нет. В описании std::map сказано, что оператор [] ВСЕГДА создаёт элемент в таблице. В случае со String'ами такой проблемы как таковой не было, потому как даже если элемент создаётся в таблице, то он создаётся через Default'ный конструктор. Далее я беру элемент таблицы map[key] и проверяю, пустая там строка или нет.

Теперь мне нужно такое же свойство для bool (элементы таблицы являются Bool'ами). Эмпирически выглядит так, что для элемента, который я в таблицу не записывал, чтение всегда возвращает false. Но у меня нет уверенности, что сие будет так всегда. std::map - это всё-таки шаблон, а потому со всеми типами он работает одинаково и создание новой записи в таблице - это создание нового объекта через defeult'ный конструктор, который для базовых типов ничего делать не должен (т.е. элемент должен остаться неинициализированным). Техническая реализация может выглядеть таким образом, что перед созданием нового экземпляра класса в таблице память под него забивается нулями и только потом дергается new с указанием того, что объект нужно создать не абы где, а именно в этом участке памяти. Тогда для всех базовых типов реально всё по умолчанию будет обнулено

А что по этому поводу говорит стандарт? Просто я в Си++ как-то не силён

Добавлено через 1 минуту
Вариант-затычку, что вместо bool я могу сделать string и по факту, инициализирована строка или нет, трактовать это как true или False, не предлагать, ибо я сам пока могу до этого додуматься
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alex_x_x
бжни
 Аватар для alex_x_x
2441 / 1646 / 84
Регистрация: 14.05.2009
Сообщений: 7,163
08.05.2010, 20:29     Вопрос по std::map #2
C++
1
2
3
4
map< string, lex_stream > map_serv;
if( map_serv.end() != (it_map = map_serv.find( str )){
  //ключ присутствует
}
те если такого ключа нету - возвращается итератор end()

я правильно понял, что вы хотите?
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16946 / 5351 / 329
Регистрация: 30.03.2009
Сообщений: 14,389
Записей в блоге: 26
08.05.2010, 20:46  [ТС]     Вопрос по std::map #3
Хм... т.е. грубо говоря есть штатный способ, чтобы проверить, есть такой элемент или нет. Так чтоли? Т.е. для моей задачи это в принципе годится.

Но вопрос про инициализацию несуществующего значения остаётся. Если ответ на него утвердительный, то можно будет обойтись без find
alex_x_x
бжни
 Аватар для alex_x_x
2441 / 1646 / 84
Регистрация: 14.05.2009
Сообщений: 7,163
08.05.2010, 20:52     Вопрос по std::map #4
есть подозрение, что произвольное, потому что ничего вразумительного в описании, ибо для классов все понятно - вызывается конструктор по умолчанию, тут видно от реализации библиотеки будет зависить
и все-же, мне кажется использовать operator[] для проверки наличия ключа не очень удобно, тк с каждой проверкой он будет усиленно добавлять новые элементы, если вы их конечно не используете сразу для своих нужд
Manjak
 Аватар для Manjak
269 / 175 / 7
Регистрация: 12.03.2010
Сообщений: 494
08.05.2010, 21:20     Вопрос по std::map #5
Для стандартных типов конструктор по умолчанию инициализирует их нулями.
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16946 / 5351 / 329
Регистрация: 30.03.2009
Сообщений: 14,389
Записей в блоге: 26
08.05.2010, 21:31  [ТС]     Вопрос по std::map #6
Цитата Сообщение от alex_x_x Посмотреть сообщение
и все-же, мне кажется использовать operator[] для проверки наличия ключа не очень удобно, тк с каждой проверкой он будет усиленно добавлять новые элементы, если вы их конечно не используете сразу для своих нужд
Описывать свою программу долго, но это нормально, ибо всё равно элемент с этим ключом заведётся (после проверки)

Вопрос я задал из тех соображений, что может кто-то стандарт Си++ хорошо знает, ибо вопрос в первую очередь к ним

Цитата Сообщение от Manjak Посмотреть сообщение
Для стандартных типов конструктор по умолчанию инициализирует их нулями
С каких это пор? Что-то впервые такое слышу
alex_x_x
бжни
 Аватар для alex_x_x
2441 / 1646 / 84
Регистрация: 14.05.2009
Сообщений: 7,163
08.05.2010, 21:34     Вопрос по std::map #7
Цитата Сообщение от Evg Посмотреть сообщение
С каких это пор? Что-то впервые такое слышу
ну вполне возможно, ведь vector<int> v(10); заполняет все элементы нулями
Manjak
 Аватар для Manjak
269 / 175 / 7
Регистрация: 12.03.2010
Сообщений: 494
08.05.2010, 21:48     Вопрос по std::map #8
Цитата Сообщение от Evg Посмотреть сообщение
С каких это пор? Что-то впервые такое слышу
С пор стандарта, а для поиска лучше map::find использовать
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16946 / 5351 / 329
Регистрация: 30.03.2009
Сообщений: 14,389
Записей в блоге: 26
08.05.2010, 21:59  [ТС]     Вопрос по std::map #9
alex_x_x, в 5'м посту говорилось про конструкторы базовых типов. Конструктор для int'а не инициализирует нулём. Или всё-таки инициализирует?

Если взять вот такой исходник:

C++
1
2
int *g;
void func (void) { g = new int; }
То в коде виден только вызов new (по сути malloc), но кода инициализации нет

Если vector<int> заполняет нулями, то один из возможных способов - который я описывал в первом посте. Вопрос в том, должно ли это делаться по стандарту?

Добавлено через 4 минуты
Цитата Сообщение от Manjak Посмотреть сообщение
Для стандартных типов конструктор по умолчанию инициализирует их нулями.
Цитата Сообщение от Manjak Посмотреть сообщение
С пор стандарта, а для поиска лучше map::find использовать
А можешь ткнуть носом в стандарт? Или конкретный пример для подтверждения своих слов. Я привёл исходник, глядя на код от которого я вижу, что инициализации не делается
Manjak
 Аватар для Manjak
269 / 175 / 7
Регистрация: 12.03.2010
Сообщений: 494
08.05.2010, 22:04     Вопрос по std::map #10
int main()
{
int a = int();
double b = double();
float c = float();
cout << a << "\t" << b << "\t" << c << endl;
system("pause");
return 0;
}
Простая проверка, можеш так же сделать для остальных типов
CyBOSSeR
Эксперт C++
 Аватар для CyBOSSeR
2295 / 1665 / 86
Регистрация: 06.03.2009
Сообщений: 3,675
08.05.2010, 22:14     Вопрос по std::map #11
Цитата Сообщение от Evg Посмотреть сообщение
Конструктор для int'а не инициализирует нулём. Или всё-таки инициализирует?
Если конструктор вызвать явно (что std::map и делает), то инициализирует.
Manjak
 Аватар для Manjak
269 / 175 / 7
Регистрация: 12.03.2010
Сообщений: 494
08.05.2010, 22:16     Вопрос по std::map #12
int a; резервирует память для инта, но никак не инициализирует значение, а конструктор дергается руками (хотя сам никогда не вызывал конструктор для стандартных типов и в чужом коде не видел)
alex_x_x
бжни
 Аватар для alex_x_x
2441 / 1646 / 84
Регистрация: 14.05.2009
Сообщений: 7,163
08.05.2010, 22:23     Вопрос по std::map #13
Цитата Сообщение от Manjak Посмотреть сообщение
int a = int();
могу понять int a(10); //int a = 10
это отвечает аналогии с пользовательскими классами, но int a = int(); работает, но как-то стремно выглядит, логичней былоб int a() - но так не работает)
Manjak
 Аватар для Manjak
269 / 175 / 7
Регистрация: 12.03.2010
Сообщений: 494
08.05.2010, 22:26     Вопрос по std::map #14
int a(); - функцию не напоминает?
alex_x_x
бжни
 Аватар для alex_x_x
2441 / 1646 / 84
Регистрация: 14.05.2009
Сообщений: 7,163
08.05.2010, 22:27     Вопрос по std::map #15
да не особо, каким образом?
..мне компилятор тоже самое сказал
Manjak
 Аватар для Manjak
269 / 175 / 7
Регистрация: 12.03.2010
Сообщений: 494
08.05.2010, 22:29     Вопрос по std::map #16
Конструкторы для стандартных типов - это надстройка плюсов, но реально используются механизмы С
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16946 / 5351 / 329
Регистрация: 30.03.2009
Сообщений: 14,389
Записей в блоге: 26
08.05.2010, 22:35  [ТС]     Вопрос по std::map #17
Цитата Сообщение от Manjak Посмотреть сообщение
Простая проверка, можеш так же сделать для остальных типов
Цитата Сообщение от CyBOSSeR Посмотреть сообщение
Если конструктор вызвать явно (что std::map и делает), то инициализирует.
О! А вот это уже конкретно и в точку. Т.е. сентенция такая, что Stl'евские контейнеры базовые типы инициализируют нулями?
Manjak
 Аватар для Manjak
269 / 175 / 7
Регистрация: 12.03.2010
Сообщений: 494
08.05.2010, 22:37     Вопрос по std::map #18
Контейнерам не особо важно какой тип им подали Конструктор контейнера (int count) инициализирует контейнер таким количеством элементов типа, вызывая для каждого конструктор по умолчанию
alex_x_x
бжни
 Аватар для alex_x_x
2441 / 1646 / 84
Регистрация: 14.05.2009
Сообщений: 7,163
08.05.2010, 22:38     Вопрос по std::map #19
Цитата Сообщение от Manjak Посмотреть сообщение
Конструкторы для стандартных типов - это надстройка плюсов, но реально используются механизмы С
C++
1
int func( 5 );
это какая-та чисто с-ная приблуда, такой вызов функции? О_о
просто оно компилируется, но ни разу такого не видел
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.05.2010, 22:43     Вопрос по std::map
Еще ссылки по теме:

C++ Std::map и key_comp
C++ Emplace в std::map. Как добавить элемент в std::map без копирования?
C++ Возможно ли создать контейнер std::map, в котором в качестве значения была бы ссылка на std::map?
C++ Особенности std::map
Потокобезопасность std::map::end, std::list::end C++

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

Или воспользуйтесь поиском по форуму:
Genius Ignat
1233 / 771 / 44
Регистрация: 16.09.2009
Сообщений: 2,014
08.05.2010, 22:43     Вопрос по std::map #20
int();
Это вообще напоминает создание временного~безымянного объекта:
для инициализации другого объекта.
В работе с объектами не встроенных типов, я знаю,
где такую примочку можно делать, и от нее больше польза, не желе здесь.
Зачем так ивзращаться, когда можно просто int a(0);

Добавлено через 3 минуты
Извиняюсь что не в тему
Yandex
Объявления
08.05.2010, 22:43     Вопрос по std::map
Ответ Создать тему
Опции темы

Текущее время: 23:39. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru