最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
用 (*it).m 还是 it->m
时间:2022-07-02 11:01:42 编辑:袖梨 来源:一聚教程网
用 (*it).m 还是 it->m
摘自《Extended STL》
标准库要求,所有值类型为聚合类型的迭代器必须支持指针成员选取运算符(operator ->()),下面是使用该运算符的示例代码:
struct X
{
int x;
};
some_iterator si = . . .
some_iterator si2 = . . .
some_iterator end = . . .
if( end != si &&
end != si2)
{
si->x = si2->x;
}
标准(C++-03: 24.1.1;1)要求,对一个迭代器应用指针成员选取运算符,在语义上等同于先对其应用解引用运算符,再应用点号成员选取运算符,即it->m与(*it).m等效。
可惜,使用该运算符会遇上麻烦。
假设我们有一个容器类型C,它的实例保存智能指针类型P的实例,P用于管理对象生存期。P上定义了一个release()方法用于提早释放对象。进一步假设,被P管理的类型T上也定义了一个release()方法。在下面代码片断中,我们希望通过该容器的迭代器类型I的一个实例,调用T::release()方法:
C cont = . . .
I it = cont.begin();
it->release();
不幸的是,这段代码调用的不是T::release()方法,它调用的是P::release()方法,从而销毁了T的实例。当我们再次使用cont这个容器的时候,就可能遇到各种奇怪的问题,以下代码才是真正实现我们想法的代码:
C cont = . . .
摘自《Extended STL》
标准库要求,所有值类型为聚合类型的迭代器必须支持指针成员选取运算符(operator ->()),下面是使用该运算符的示例代码:
struct X
{
int x;
};
some_iterator
some_iterator
some_iterator
if( end != si &&
end != si2)
{
si->x = si2->x;
}
标准(C++-03: 24.1.1;1)要求,对一个迭代器应用指针成员选取运算符,在语义上等同于先对其应用解引用运算符,再应用点号成员选取运算符,即it->m与(*it).m等效。
可惜,使用该运算符会遇上麻烦。
假设我们有一个容器类型C,它的实例保存智能指针类型P的实例,P用于管理对象生存期。P上定义了一个release()方法用于提早释放对象。进一步假设,被P管理的类型T上也定义了一个release()方法。在下面代码片断中,我们希望通过该容器的迭代器类型I的一个实例,调用T::release()方法:
C cont = . . .
I it = cont.begin();
it->release();
不幸的是,这段代码调用的不是T::release()方法,它调用的是P::release()方法,从而销毁了T的实例。当我们再次使用cont这个容器的时候,就可能遇到各种奇怪的问题,以下代码才是真正实现我们想法的代码:
C cont = . . .
相关文章
- 三国志幻想大陆2枭之歌颜良有什么玩法技巧 10-14
- 荒原曙光银鬃怎么捕捉 10-14
- 崩坏因缘精灵阿斯维加斯强度如何 10-14
- 火环尼芙海姆位置在哪里 10-14
- 迷雾大陆机械师流派构筑指南-迷雾大陆机械师流派构筑参考 10-14
- 羊蹄山之魂是什么类型的游戏 羊蹄山之魂游戏类型介绍 10-14