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

C++

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 56, средняя оценка - 4.95
Evg
Эксперт CАвтор FAQ
17934 / 6162 / 408
Регистрация: 30.03.2009
Сообщений: 16,916
Записей в блоге: 27
#1

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

08.05.2010, 20:13. Просмотров 7158. Ответов 27
Метки нет (Все метки)

В качестве хэш-таблицы для строк (AnsiString) я использовал std::map. От таблицы мне нужно было ещё и такое свойство: я хотел иметь информацию о том, присутсвует данный ключ в таблице или нет. В описании std::map сказано, что оператор [] ВСЕГДА создаёт элемент в таблице. В случае со String'ами такой проблемы как таковой не было, потому как даже если элемент создаётся в таблице, то он создаётся через Default'ный конструктор. Далее я беру элемент таблицы map[key] и проверяю, пустая там строка или нет.

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

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

Добавлено через 1 минуту
Вариант-затычку, что вместо bool я могу сделать string и по факту, инициализирована строка или нет, трактовать это как true или False, не предлагать, ибо я сам пока могу до этого додуматься
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.05.2010, 20:13
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Вопрос по std::map (C++):

переписать std::map - C++
Добрый вечер! Есть работающая программа, в которой используется map, все работало хорошо, но теперь немного изменились условия и объем...

Обход элементов std::map в порядке их создания - C++
Имеется ассоциативный массив и его заполнение: std::map<unsigned,string> arr; arr = "abc"; arr = "def"; arr = "ghi"; Теперь...

std::string, std::fstream, ошибка кучи - C++
где то начало вылетать при операции += с локальной переменной std::string. Заменил на свой qString. Замечательно, то же самое... ошибка при...

как проинициализировать std::stack<const int> obj ( std::stack<int>{} ); - C++
добрый день. вопрос в коде: http://rextester.com/VCVVML6656 #include &lt;iostream&gt; #include &lt;stack&gt; //-std=c++14...

std::filesystem && std::asio и пр - C++
Пытался найти хоть какие-то сроки включения всего этого в стандарт (так же ожидается lexical_cast, any, string_algo и т.д.) и вообщем везде...

map warnings - C++
Здравствуйте, подключил map к проекту и получаю при компиляции 90 с лишним предупреждений. #include &lt;iostream&gt; #include &lt;string&gt; ...

27
alex_x_x
бжни
2447 / 1652 / 84
Регистрация: 14.05.2009
Сообщений: 7,162
08.05.2010, 20:29 #2
C++
1
2
3
4
map< string, lex_stream > map_serv;
if( map_serv.end() != (it_map = map_serv.find( str )){
  //ключ присутствует
}
те если такого ключа нету - возвращается итератор end()

я правильно понял, что вы хотите?
1
Evg
Эксперт CАвтор FAQ
17934 / 6162 / 408
Регистрация: 30.03.2009
Сообщений: 16,916
Записей в блоге: 27
08.05.2010, 20:46  [ТС] #3
Хм... т.е. грубо говоря есть штатный способ, чтобы проверить, есть такой элемент или нет. Так чтоли? Т.е. для моей задачи это в принципе годится.

Но вопрос про инициализацию несуществующего значения остаётся. Если ответ на него утвердительный, то можно будет обойтись без find
0
alex_x_x
бжни
2447 / 1652 / 84
Регистрация: 14.05.2009
Сообщений: 7,162
08.05.2010, 20:52 #4
есть подозрение, что произвольное, потому что ничего вразумительного в описании, ибо для классов все понятно - вызывается конструктор по умолчанию, тут видно от реализации библиотеки будет зависить
и все-же, мне кажется использовать operator[] для проверки наличия ключа не очень удобно, тк с каждой проверкой он будет усиленно добавлять новые элементы, если вы их конечно не используете сразу для своих нужд
0
Manjak
269 / 175 / 7
Регистрация: 12.03.2010
Сообщений: 494
08.05.2010, 21:20 #5
Для стандартных типов конструктор по умолчанию инициализирует их нулями.
0
Evg
Эксперт CАвтор FAQ
17934 / 6162 / 408
Регистрация: 30.03.2009
Сообщений: 16,916
Записей в блоге: 27
08.05.2010, 21:31  [ТС] #6
Цитата Сообщение от alex_x_x Посмотреть сообщение
и все-же, мне кажется использовать operator[] для проверки наличия ключа не очень удобно, тк с каждой проверкой он будет усиленно добавлять новые элементы, если вы их конечно не используете сразу для своих нужд
Описывать свою программу долго, но это нормально, ибо всё равно элемент с этим ключом заведётся (после проверки)

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

Цитата Сообщение от Manjak Посмотреть сообщение
Для стандартных типов конструктор по умолчанию инициализирует их нулями
С каких это пор? Что-то впервые такое слышу
0
alex_x_x
бжни
2447 / 1652 / 84
Регистрация: 14.05.2009
Сообщений: 7,162
08.05.2010, 21:34 #7
Цитата Сообщение от Evg Посмотреть сообщение
С каких это пор? Что-то впервые такое слышу
ну вполне возможно, ведь vector<int> v(10); заполняет все элементы нулями
0
Manjak
269 / 175 / 7
Регистрация: 12.03.2010
Сообщений: 494
08.05.2010, 21:48 #8
Цитата Сообщение от Evg Посмотреть сообщение
С каких это пор? Что-то впервые такое слышу
С пор стандарта, а для поиска лучше map::find использовать
0
Evg
Эксперт CАвтор FAQ
17934 / 6162 / 408
Регистрация: 30.03.2009
Сообщений: 16,916
Записей в блоге: 27
08.05.2010, 21:59  [ТС] #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 использовать
А можешь ткнуть носом в стандарт? Или конкретный пример для подтверждения своих слов. Я привёл исходник, глядя на код от которого я вижу, что инициализации не делается
0
Manjak
269 / 175 / 7
Регистрация: 12.03.2010
Сообщений: 494
08.05.2010, 22:04 #10
int main()
{
int a = int();
double b = double();
float c = float();
cout << a << "\t" << b << "\t" << c << endl;
system("pause");
return 0;
}
Простая проверка, можеш так же сделать для остальных типов
1
CyBOSSeR
Эксперт С++
2303 / 1673 / 86
Регистрация: 06.03.2009
Сообщений: 3,675
08.05.2010, 22:14 #11
Цитата Сообщение от Evg Посмотреть сообщение
Конструктор для int'а не инициализирует нулём. Или всё-таки инициализирует?
Если конструктор вызвать явно (что std::map и делает), то инициализирует.
1
Manjak
269 / 175 / 7
Регистрация: 12.03.2010
Сообщений: 494
08.05.2010, 22:16 #12
int a; резервирует память для инта, но никак не инициализирует значение, а конструктор дергается руками (хотя сам никогда не вызывал конструктор для стандартных типов и в чужом коде не видел)
0
alex_x_x
бжни
2447 / 1652 / 84
Регистрация: 14.05.2009
Сообщений: 7,162
08.05.2010, 22:23 #13
Цитата Сообщение от Manjak Посмотреть сообщение
int a = int();
могу понять int a(10); //int a = 10
это отвечает аналогии с пользовательскими классами, но int a = int(); работает, но как-то стремно выглядит, логичней былоб int a() - но так не работает)
0
Manjak
269 / 175 / 7
Регистрация: 12.03.2010
Сообщений: 494
08.05.2010, 22:26 #14
int a(); - функцию не напоминает?
0
alex_x_x
бжни
2447 / 1652 / 84
Регистрация: 14.05.2009
Сообщений: 7,162
08.05.2010, 22:27 #15
да не особо, каким образом?
..мне компилятор тоже самое сказал
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.05.2010, 22:27
Привет! Вот еще темы с ответами:

Map c++ вывод на консоль по ключу - C++
Нужна помощь! У меня есть контейнер : map &lt;string, int&gt; m1 = { { &quot;wq&quot;, 1 }, { &quot;etr&quot;, 2 }, { &quot;weg&quot;, 4 } }; Нужно получить...

Получить индекс типа в mpl::map`е - C++
всем привет. есть mpl карта типов(key -&gt; value). нужно получить индекс типа имея только ключ. где-то накосячил. но непойму где. ...

Можно ли просчитать дистанцию между переменными в map? - C++
values.push_back(necessaryCoor) - - - - Вектор содержит только координаты points.push_back(newPoints) - - - Вектор содержит только айди...

std::defaultfloat - C++
Есть такая тема в новом стандарте как std::defaultfloat Описание: http://www.cplusplus.com/reference/ios/defaultfloat/ В стандарте...


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

Или воспользуйтесь поиском по форуму:
15
Yandex
Объявления
08.05.2010, 22:27
Ответ Создать тему
Опции темы

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