8

以下代码无法编译。该错误似乎是对合并例程的某种模棱两可的调用。我的理解是 STL 在 std 命名空间中有一个合并例程,但据我所知,下面代码中的名称合并应该是唯一的。

如果我将合并重命名为 xmerge,一切正常。问题可能是什么?名字冲突从何而来?

http://codepad.org/uAKciGy5

#include <iostream>
#include <iterator>
#include <vector>

template<typename InputIterator1,
         typename InputIterator2,
         typename OutputIterator>
void merge(const InputIterator1 begin1, const InputIterator1 end1,
           const InputIterator2 begin2, const InputIterator2 end2,
           OutputIterator out)
{
   InputIterator1 itr1 = begin1;
   InputIterator2 itr2 = begin2;
   while ((itr1 != end1) && (itr2 != end2))
   {
      if (*itr1 < *itr2)
         *out = *itr1, ++itr1;
      else
         *out = *itr2, ++itr2;
      ++out;
   }
   while (itr1 != end1) *out++ = *itr1++;
   while (itr2 != end2) *out++ = *itr2++;
}

int main()
{
   std::vector<int> l1;
   std::vector<int> l2;
   std::vector<int> merged_list;

   merge(l1.begin(),l1.end(),
         l2.begin(),l2.end(),
         std::back_inserter(merged_list));

   return 0;
}
4

1 回答 1

17

编译器在您的函数merge和. 用于消除这种歧义。此调用不明确,因为编译器在使用非限定函数名时使用参数依赖查找来搜索函数。std::mergealgorithm::merge

于 2011-02-02T10:17:07.890 回答