hash_map.insert vs []
- 19.03.09, 15:57
Часто в коде можно увидеть использование конструкции
typedef hash_map<Word32, class SomeClass> TSomeHashMap;
TSomeHashMap shm;
shm[10] = SomeClass(val1, val2);
Более оптимальный, в большинстве случаев, следующий код:
shm.insert(TSomeHashMap::value _type(10, SomeClass(val1, val2)));
Лишние затраты в первом случае получаются из-за того что оператор [] это фактически:
(*((shm.insert(TSomeHashMap::v alue_type(10, SomeClass()))).first)).second = SomeClass(val1, val2);
Т.е...
3