gpt4 book ai didi

c++ - STL 算法 : Why no additional interface for containers (additional to iterator pairs)?

转载 作者:太空宇宙 更新时间:2023-11-04 12:54:43 27 4
gpt4 key购买 nike

我想知道为什么 STL 没有重载它们的算法函数,这样我就可以通过简单地提供一个容器而不是采用更冗长的方式来传递开始 + 结束迭代器来调用它们。我当然理解为什么我们还想使用迭代器对来处理容器/数组的子序列,但是,几乎所有对这些方法的调用都使用整个容器:

std::for_each(myVector.begin(), myVector.end(), doSomething);

我会发现直接编写更方便、可读和可维护

std::for_each(myVector, doSomething);

STL 不提供这些重载 有什么原因吗? [编辑:我不是要用这个受限制的接口(interface)替换接口(interface),而是要提供一个基于容器的 iterface!] 它们会引入歧义吗?我在想这样的事情:

template<typename _Container, typename _Funct>
inline _Funct for_each(_Container c, _Funct f) {
return for_each(begin(c), end(c), f);
}

我错过了什么吗?

最佳答案

它们确实为许多算法引入了歧义。很多<algorithm>看起来像

template<class iterator>
void do_something(iterator, iterator);

template<class iterator, class funct>
void do_something(iterator, iterator, funct);

如果你添加额外的重载

template<class container, class funct>
void do_something(container, funct);

编译器将很难弄清楚 do_something(x, y) 是什么方法。 如果 xy是一样的 type , 它将同时匹配 iterator = typecontainer = type, funct = type . *)

C++11 试图用 "concepts" 解决这个问题可以识别容器和迭代器之间的区别。然而,这些“概念”被证明太复杂而无法纳入标准,因此这些重载也没有。

*) 编译器在这里不同意,Comeau 编译器声称它是不明确的,g++ 4.5 和 MSVC 10 调用第一个函数。


在评论中进行了非常长时间的讨论后,这里有一个示例没有按预期工作 - 使用容器适配器也可以兼作谓词。

#include <iostream>
#include <vector>

template<class iterator>
void test(iterator, iterator)
{
std::cout << "test iterator\n";
}

template<class iterator, class predicate>
void test(iterator, iterator, predicate)
{
std::cout << "test iterator, predicate\n";
}

template<class container, class predicate>
void test(const container& cont, predicate compare)
{
std::cout << "test container, predicate\n";

test(cont.begin(), cont.end(), compare);
}

template<class container>
class adapter
{
public:
typedef typename container::iterator iterator;

adapter(container* cont) : cont(cont)
{ }

iterator begin() const
{ return cont->begin(); }

iterator end() const
{ return cont->end(); }

bool operator()(const iterator& one, const iterator& two)
{ return *one < *two; }

private:
container* cont;
};

int main()
{
std::vector<int> v;

adapter<std::vector<int>> a(&v);

test(a, a);

}

输出:

test iterator

http://ideone.com/wps2tZ

关于c++ - STL 算法 : Why no additional interface for containers (additional to iterator pairs)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47084302/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com