我的问题
我有这两个函数头:
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、密度和压力)的类。如果 header 中没有频率参数,我想只得到一个 double 值。直接组件还指示您是否写 f=0
在 header 中,但在这种情况下,我得到了一个复杂的值。我不想像这样编辑整个程序: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);
...第一个函数出现这个错误:
'
ASSERT_THROW( xxx.harmonic(d,d,d), ERROR)
' is ambiguous ' Candidates are:
FlowTools::LocalFlow<double> & harmonic(int, int, int)
FlowTools::LocalFlow<std::complex<double>> & harmonic(int, int, int, int) '
我的错误是什么?
最佳答案
删除 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;
关于c++ - 重载函数不明确,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34812222/