У меня есть шаблонный класс Baz , который содержит вложенный класс sub . Я хотел бы определить хэш -функцию для этого подкласса, специализируя STD :: HASH. Однако, похоже, это не работает. < /P>
#include
struct Foo {
struct Sub {
};
};
template
struct Bar {
};
template
struct Baz {
struct Sub {
int x;
};
};
// declare hash for Foo::Sub - all right
namespace std {
template
struct hash< Foo::Sub >;
}
// declare hash for Bar - all right
namespace std {
template
struct hash< Bar >;
}
// declare hash function for Baz::Sub - doesn't work!
namespace std {
template
struct hash< Baz::Sub >;
}
// Adding typename produces a different error.
namespace std {
template
struct hash< typename Baz::Sub >;
}
< /code>
gcc 4.5.3 Жаления: < /p>
$ g++ -std=c++0x -c hash.cpp
hash.cpp:34:30: error: type/value mismatch at argument 1 in template parameter list for ‘template struct std::hash’
hash.cpp:34:30: error: expected a type, got ‘Baz::Sub’
hash.cpp:40:12: error: template parameters not used in partial specialization:
hash.cpp:40:12: error: ‘T’
< /code>
Обновление < /strong> < /p>
То, что я действительно пытаюсь сделать, - это реализовать контейнер, который поддерживает стабильные ссылки < /em> (не в смысле C ++) к элементам внутри него. Я хочу позволить пользователю вставить эти ссылки в std :: unoromeded_set и аналогично, и использовать их для эффективного доступа или изменения существующих элементов. Следующее - просто макет, а не точный контейнер, который я реализую. Проблема заключается в определении хеш -функции для эталонного типа. < /P>
template
class Container {
public:
class Reference {
public:
// operator==, operator!=, operator< ...., isNull()
private:
size_t index; // index into m_entries (or could be anything else)
// possibly more stuff
};
Reference insert (const T &value);
Reference find (const T &value);
void remove (Reference r);
Reference first ();
Reference next (Reference prev);
private:
struct Entry { T value, ... };
std::vector m_entries;
};
Подробнее здесь: https://stackoverflow.com/questions/104 ... late-class
Специализация Std :: hash для вложенного класса в классе шаблонов ⇐ C++
Программы на C++. Форум разработчиков
-
Anonymous
1750114258
Anonymous
У меня есть шаблонный класс Baz , который содержит вложенный класс sub . Я хотел бы определить хэш -функцию для этого подкласса, специализируя STD :: HASH. Однако, похоже, это не работает. < /P>
#include
struct Foo {
struct Sub {
};
};
template
struct Bar {
};
template
struct Baz {
struct Sub {
int x;
};
};
// declare hash for Foo::Sub - all right
namespace std {
template
struct hash< Foo::Sub >;
}
// declare hash for Bar - all right
namespace std {
template
struct hash< Bar >;
}
// declare hash function for Baz::Sub - doesn't work!
namespace std {
template
struct hash< Baz::Sub >;
}
// Adding typename produces a different error.
namespace std {
template
struct hash< typename Baz::Sub >;
}
< /code>
gcc 4.5.3 Жаления: < /p>
$ g++ -std=c++0x -c hash.cpp
hash.cpp:34:30: error: type/value mismatch at argument 1 in template parameter list for ‘template struct std::hash’
hash.cpp:34:30: error: expected a type, got ‘Baz::Sub’
hash.cpp:40:12: error: template parameters not used in partial specialization:
hash.cpp:40:12: error: ‘T’
< /code>
Обновление < /strong> < /p>
То, что я действительно пытаюсь сделать, - это реализовать контейнер, который поддерживает стабильные ссылки < /em> (не в смысле C ++) к элементам внутри него. Я хочу позволить пользователю вставить эти ссылки в std :: unoromeded_set и аналогично, и использовать их для эффективного доступа или изменения существующих элементов. Следующее - просто макет, а не точный контейнер, который я реализую. Проблема заключается в определении хеш -функции для эталонного типа. < /P>
template
class Container {
public:
class Reference {
public:
// operator==, operator!=, operator< ...., isNull()
private:
size_t index; // index into m_entries (or could be anything else)
// possibly more stuff
};
Reference insert (const T &value);
Reference find (const T &value);
void remove (Reference r);
Reference first ();
Reference next (Reference prev);
private:
struct Entry { T value, ... };
std::vector m_entries;
};
Подробнее здесь: [url]https://stackoverflow.com/questions/10466652/specializing-stdhash-for-nested-class-in-a-template-class[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия