尝试从另一个文件中重载<
此代码有效
(foo.hpp)
#ifndef FOO_HPP
#define FOO_HPP
enum class Foo { a, b };
#endif
(bar.cpp)
#include "foo.hpp"
#include <iostream>
std::ostream& operator<<(std::ostream& out, Foo x) {
switch(x) {
case Foo::a :
out << "a";
break;
case Foo::b :
out << "b";
break;
}
return out;
}
int main(int argc, char ** argv) {
Foo x {Foo::a};
std::cout << x << std::endl;
return 0;
}
(Makefile)
CC=g++
CFLAGS=--std=c++11 -Wall
bar : bar.o
$(CC) $(CFLAGS) bar.o -o bar
bar.o : bar.cpp foo.hpp
$(CC) $(CFLAGS) -c bar.cpp foo.hpp
(./bar的输出)
a
现在,如果我创建foo.cpp,并在其中移动
std::ostream& operator<<(std::ostream& , Foo)
的定义,并以此方式修改我的MakefileCC=g++
CFLAGS=--std=c++11 -Wall
bar : bar.o foo.o
$(CC) $(CFLAGS) bar.o foo.o -o bar
foo.o : foo.cpp foo.hpp
$(CC) $(CFLAGS) -c foo.cpp foo.hpp
bar.o : bar.cpp foo.hpp
$(CC) $(CFLAGS) -c bar.cpp foo.hpp
它不起作用,并且出现很多编译器错误,从
bar.cpp: In function ‘int main(int, char**)’:
bar.cpp:6:13: error: no match for ‘operator<<’ (operand types are ‘std::ostream {aka std::basic_ostream<char>}’ and ‘Foo’)
std::cout << x << std::endl;
^
和其他错误非常相似。
为什么呢
最佳答案
operator <<
仍然像其他函数一样(带有一些其他属性)。它的声明必须在所有要使用它的文件中可见。因此,如果将其定义从main.cpp
移到foo.cpp
,则需要在foo.hpp
中放置一个声明:
std::ostream& operator<<(std::ostream& out, Foo x);
关于c++ - 为什么我不能在另一个文件中重载<<操作符?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/40742625/