c – 为什么std :: advance不返回生成的迭代器?
发布时间:2020-12-16 07:12:48 所属栏目:百科 来源:网络整理
导读:目前,std :: advance的设计如下: template class InputIt,class Distance void advance( InputIt it,Distance n ); 但是,我经常发现自己想要的东西: template class InputIt,class Distance InputIt advance( InputIt it,Distance n ); 那么,当前设计的基
目前,std :: advance的设计如下:
template< class InputIt,class Distance > void advance( InputIt& it,Distance n ); 但是,我经常发现自己想要的东西: template< class InputIt,class Distance > InputIt advance( InputIt it,Distance n ); 那么,当前设计的基本原理是什么?这是出于性能考虑吗?请注意,std :: next和std :: prev会返回生成的迭代器. 解决方法
没有技术原因阻止它返回对输入值的引用,并且任何合理的编译器应该能够在不使用时优化返回值.所以如果他们愿意,他们可以这样做.
我认为从API设计的角度来看,他们的选择是有道理的 – std :: prev和std :: next采用迭代器并分别返回指向上一个或下一个元素的不同迭代器,而不修改输入. 另一方面,std :: advance修改输入.如果它返回对输入迭代器的引用,则可能会混淆一个函数,该函数返回一个副本而不会就地修改输入.这可能是危险的. 请注意,std :: advance适用于InputIterators,其中包括迭代具有副作用的迭代器(诸如从流中读取的迭代器之类的东西),但是std :: prev和std :: next仅适用于没有副作用的ForwardIterators. . 因此,返回一个单独的值(如std :: prev和std :: next)将是一个坏主意 – 你最终会在同一个流上使用两个迭代器,这可能会对彼此产生负面影响. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |