重载功能是不明确的

时间:2016-01-15 13:31:44

标签: c++ unit-testing overloading googletest

我的问题

我有两个功能标题:

const FlowTools::LocalFlow < double >& harmonic( const int i, const int j, const int k ) const;

const FlowTools::LocalFlow < std::complex < double > >& harmonic( const int i, const int j, const int k, const int f ) const;

LocalFlow只是一个包含五个物理参数(速度3D,密度和压力)的类。如果标题中没有频率参数,我想只获得双倍值。直接组件还指示您是否在标头中写f=0,但在这种情况下,我得到一个复杂的值。我不想像这样编辑整个程序:xxx.harmonic()。real()。在重载函数之前,它调用flowField(int i, int j, int k)。我做重构。

现在,我正在使用Google Test(C ++单元测试库)测试该功能,如下所示:

ASSERT_THROW(xxx.harmonic(d,d,d), ERROR);

ASSERT_THROW(xxx.harmonic(d,d,d,0), ERROR);

...并为第一个函数获取此错误:

  

&#39; ASSERT_THROW( xxx.harmonic(d,d,d), ERROR)&#39;是模糊的&#39;候选人   是:

     

FlowTools::LocalFlow<double> & harmonic(int, int, int)

     

FlowTools::LocalFlow<std::complex<double>> & harmonic(int, int, int, int) '

我的错误是什么?

1 个答案:

答案 0 :(得分:1)

删除f = 0,使其不再含糊不清。

所以而不是

const FlowTools::LocalFlow<double>&
harmonic(int i, int j, int k) const;

const FlowTools::LocalFlow<std::complex<double>>&
harmonic(int i, int j, int k, int f = 0) const;
// f = 0 make ambiguous call when not provided

使用

const FlowTools::LocalFlow<double>&
harmonic(int i, int j, int k) const;

const FlowTools::LocalFlow<std::complex<double>>&
harmonic(int i, int j, int k, int f) const;