Специализация Std :: hash для вложенного класса в классе шаблоновC++

Программы на C++. Форум разработчиков
Ответить Пред. темаСлед. тема
Anonymous
 Специализация Std :: hash для вложенного класса в классе шаблонов

Сообщение 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;
};


Подробнее здесь: https://stackoverflow.com/questions/104 ... late-class
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «C++»