我需要帮助理解一些C++运算符重载语句。类声明如下:运算符为C++映射重载
template <class key_t, class ipdc_t>
class ipdc_map_template_t : public ipdc_lockable_t
{
...
typedef map<key_t,
ipdc_t*,
less<key_t>> map_t;
...
类的创建者创建了一个迭代器的内部映射结构:
struct iterator : public map_t::iterator
{
iterator() {}
iterator(const map_t::iterator & it)
: map_t::iterator(it) {}
iterator(const iterator & it)
: map_t::iterator(
*static_cast<const map_t::iterator *>(&it)) {}
operator key_t() {return ((this->operator*()).first);} // I don't understand this.
operator ipdc_t*() const {return ((this->operator*()).second);} // or this.
};
并开始()和结束()返回begin()和地图的结束():
iterator begin() {IT_ASSERT(is_owner()); return map.begin();}
iterator end() {return map.end();}
我的问题是,如果我有一个迭代,我怎么使用这些重载拿到钥匙和价值?
ipdc_map_template_t::iterator iter;
for(iter = my_instance.begin();
iter != my_instance.end();
++iter)
{
key_t my_key = ??????;
ipdc_t *my_value = ??????;
}
下面提供的解决方案是不够好(用,但该值,PE指针问题可能),所以在不会详细说明...但无论如何:使用隐式强制转换作为合成糖是坏的和危险的设计,恕我直言... – paercebal 2008-09-26 20:57:43