我的问题
我有两个功能标题:
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) '
我的错误是什么?
答案 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;