使用我自己的plus()函数时出现奇怪的g ++编译器错误("std :: plus不是函数")

Fra*_*ank 4 c++ compiler-errors g++

我从g ++中得到一个奇怪的编译器错误.

std::plus is not a function对于以下代码,它说" ",即使我没有包含<functional>,我也没有使用std错误发生的地方.

这是代码:

#include <iostream>

template<class T1, class T2, class T3>
struct MyStruct {
  T1 t1; T2 t2; T3 t3;
  MyStruct() {}
  MyStruct(T1 const& t1_, T2 const& t2_, T3 const& t3_)
    : t1(t1_), t2(t2_), t3(t3_) {}
};

template<class T1, class T2, class T3>
MyStruct<T1, T2, T3> plus(MyStruct<T1, T2, T3> const& x,
              MyStruct<T1, T2, T3> const& y) {
  // ...
}

int main() {
  typedef MyStruct<int, double, std::string> Struct;
  Struct x(2, 5.6, "bar");
  Struct y(6, 4.1, "foo");
  Struct result = plus(x, y);
}
Run Code Online (Sandbox Code Playgroud)

这是完整的错误(稍微重新格式化):

/usr/include/c++/4.2.1/bits/stl_function.h: In function 'int main()':
/usr/include/c++/4.2.1/bits/stl_function.h:134:
    error: 'template<class _Tp> struct std::plus' is not a function,
plus3.cc:13: error:
   conflict with 'template<class T1, class T2, class T3> 
     MyStruct<T1, T2, T3> plus(const MyStruct<T1, T2, T3>&, 
       const MyStruct<T1, T2, T3>&)'
plus3.cc:21: error:   in call to 'plus'
Run Code Online (Sandbox Code Playgroud)

有谁知道这是为什么以及如何避免错误?我真的很想打电话给这个功能plus.

当我的plus函数没有3个模板参数时,不会发生错误,这在查看以下定义后有一定意义std::plus:

  template <class _Tp>
    struct plus : public binary_function<_Tp, _Tp, _Tp>
Run Code Online (Sandbox Code Playgroud)

但它仍然很奇怪,因为std::plus在那一点上甚至不应该知道.

更新:

在回答一些答案时,我会粘贴稍微修改过的代码,这也会给出错误.我的plus函数在namespace foo这里,它是从同一个命名空间调用的,所以不需要使用它来限定它foo:::

#include <string>

namespace foo {

template<class T1, class T2, class T3>
struct MyStruct {
  T1 t1; T2 t2; T3 t3;
  MyStruct() {}
  MyStruct(T1 const& t1_, T2 const& t2_, T3 const& t3_)
      : t1(t1_), t2(t2_), t3(t3_) {}
};

template<class T1, class T2, class T3>
MyStruct<T1, T2, T3> plus(MyStruct<T1, T2, T3> const& x,
                          MyStruct<T1, T2, T3> const& y) {
  // ...                                                                                                                        
}

template<class T1, class T2, class T3>
MyStruct<T1, T2, T3> bar(MyStruct<T1, T2, T3> const& x,
                         MyStruct<T1, T2, T3> const& y) {
  return plus(x, y);
}

} // end foo                                                                                                                    

int main() {
  typedef foo::MyStruct<int, double, std::string> Struct;
  Struct x(2, 5.6, "bar");
  Struct y(6, 4.1, "foo");
  Struct result = foo::bar(x, y);
}
Run Code Online (Sandbox Code Playgroud)

Mar*_*ork 5

这是因为std :: plus不是一个函数.

您的函数plus位于全局命名空间中,因此您需要这样做

Struct result = ::plus(x, y);
Run Code Online (Sandbox Code Playgroud)

它试图使用std :: plus的原因是因为你没有在你想要的版本中明确,所以编译器使用Koenig查找,通过它的参数找到加号.