大佬教程收集整理的这篇文章主要介绍了c – 为什么编译器找不到这个运算符<< overload?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
boost::variant
中的标准库容器的特定实例化.这是一个说明问题的小例子:
#include <iostream> #include <vector> std::ostream & operator<<( std::ostream & os,const std::vector< int > & ) { os << "Streaming out std::vector< int >"; return os; } std::ostream & operator<<( std::ostream & os,const std::vector< double > & ) { os << "Streaming out std::vector< double >"; return os; } #include <boost/variant.hpp> typedef boost::variant< std::vector< int >,std::vector< double > > MyVariant; int main( int argc,char * argv[] ) { std::cout << MyVariant(); return 0; }
boost/variant/detail/variant_io.hpp:64:14: error: invalid operands to binary expression ('std::basic_ostream<char>' and 'const std::vector<int,std::allocator<int>>') out_ << operand; ~~~~ ^ ~~~~~~~
我意识到#include< boost / variant.hpp>在一个奇怪的地方.我很确定问题与模板中的两阶段名称查找有关,所以我移动了#include以尝试从clang documentation on lookup实现修复#1.修复#2来自该文档并不是一个好选择,因为我相信添加我的重载运算符<<到std命名空间会导致未定义的行为. 不应该在#include允许编译器找到定义之前定义我的运算符<< s?这个技术似乎适用于以下示例,改编自同一个clang页面.
#include <iostream> namespace ns { struct Data {}; } std::ostream& operator<<(std::ostream& out,const ns::Data & data) { return out << "Some data"; } namespace ns2 { template<typename T> void Dump( std::ostream & out,const T & value) { out << value; } } int main( int argc,char * argv[] ) { ns2::Dump( std::cout,ns::Data() ); }
移动声明并没有帮助:第二阶段名称查找实际上并不依赖于声明的顺序,除了声明必须在实例化之前.唯一正确的解决方法是在阶段II查找中寻找名称空间中的运算符,这几乎意味着要打印的类型必须涉及用户定义的类型.
以上是大佬教程为你收集整理的c – 为什么编译器找不到这个运算符<< overload?全部内容,希望文章能够帮你解决c – 为什么编译器找不到这个运算符<< overload?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。