C 11中的std :: complex的C 11复制赋值 – 与’operator’不匹配

下面的代码无法使用-std = c 0x开关使用g版本4.5.0进行编译.我收到以下错误消息:
error: no match for 'operator+' in 'std::pow [with _Tp = float,_Up = int,typename __gnu_cxx::__promote_2<_Tp,_Up>::__type = double](((const std::complex<float>&)((const std::complex<float>*)(& x))),((const int&)((const int*)(&2)))) + y'

我认为这与here提到的可分配要求有关.我应该为复杂定义我自己的复制赋值运算符吗?如果是这样,怎么样?

#include <complex>
using namespace std;

int main(int argc,char *argv[]) {
  complex<float> x,y;
  x = pow(x,2);      // ok
  x = x        + y;  // ok
  x = pow(x,2) + y;  // error
  return 0;
}

解决方法

[cmplx.over] / p3指定涉及复杂时的pow的额外重载:

Function template pow shall have additional overloads sufficient to
ensure,for a call with at least one argument of type complex<T>:

  1. If either argument has type complex<long double> or type long double,then both arguments are effectively cast to complex<long
    double>
    .

  2. Otherwise,if either argument has type complex<double>,double,or an integer type,then both arguments are effectively cast to
    complex<double>.

  3. Otherwise,if either argument has type complex<float> or float,then both arguments are effectively cast to complex<float>.

2被提升为double,而pow(complex< float>,double)返回复数< double>.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...