【问题标题】:Error: control Reaches end of non void function错误:控制到达非 void 函数的结尾
【发布时间】:2022-01-25 23:55:01
【问题描述】:

我正在学习C++,我从教科书上复制了这段代码,在编译代码时,最后出现错误。错误说:

控制到达非空函数的结尾

它位于代码的末尾:

#include "ComplexNumber.hpp"
#include <cmath>

ComplexNumber::ComplexNumber()
{
mRealPart = 0.0;
mImaginaryPart = 0.0;
}

ComplexNumber::ComplexNumber(double x, double y)
{
mRealPart = x;
mImaginaryPart = y;
}

double ComplexNumber::CalculateModulus() const
{
return sqrt(mRealPart*mRealPart+
            mImaginaryPart*mImaginaryPart);
}
double ComplexNumber::CalculateArgument() const
{
return atan2(mImaginaryPart, mRealPart);
}

ComplexNumber ComplexNumber::CalculatePower(double n) const
{
double modulus = CalculateModulus();
double argument = CalculateArgument();
double mod_of_result = pow(modulus, n);
double arg_of_result = argument*n;
double real_part = mod_of_result*cos(arg_of_result);
double imag_part = mod_of_result*sin(arg_of_result);
ComplexNumber z(real_part, imag_part);
return z;
}

ComplexNumber& ComplexNumber::operator=(const ComplexNumber& z)
{
mRealPart = z.mRealPart;
mImaginaryPart = z.mImaginaryPart;
return *this;
}

ComplexNumber ComplexNumber::operator-() const
{
ComplexNumber w;
w.mRealPart = -mRealPart;
w.mImaginaryPart = -mImaginaryPart;
return w;
}

ComplexNumber ComplexNumber::operator+(const ComplexNumber& z) const
{
ComplexNumber w;
w.mRealPart = mRealPart + z.mRealPart;
w.mImaginaryPart = mImaginaryPart + z.mImaginaryPart;
return w;
}

std::ostream& operator<<(std::ostream& output,
                     const ComplexNumber& z)
{
output << "(" << z.mRealPart << " ";
if (z.mImaginaryPart >= 0.0)
{
    output << " + " << z.mImaginaryPart << "i)";
}
else
{
    output << "- " << -z.mImaginaryPart << "i)";
}
} //-------->>>>**"Control Reaches end of non-void function"**

【问题讨论】:

  • 无论出自哪本教科书,我都不认为它有那么好。
  • 这本书是由乔·皮特-弗朗西斯和乔纳森·怀特利所著。 “C++ 科学计算指南”。我正在阅读它,因为我应该使用面向对象的方法进行一些数值计算,并且是我能找到的唯一一种,如果您有任何建议,我会很高兴听到它们。
  • 老实说,科学家和优秀的编程并不能很好地结合在一起。如果您对语言足够了解,不会养成坏习惯,那么您最终会从那些不是为教授语言而设计的书籍中获得更多。对于语言,我们有一个很好的 books 列表。
  • 谢谢 Chris!,我是一名科学家,我更习惯于使用 Java 和 Fortran,现在我必须在一个使用 C++ 的项目中工作。你是对的。即使不了解 C++,我也能发现许多不良的编程习惯。我会检查推荐的书籍清单。并努力提升你在编程界的科学家形象!

标签: c++ compiler-errors return numerical-methods


【解决方案1】:

operator&lt;&lt; 定义为返回std::ostream&amp;

std::ostream& operator<<(std::ostream& output, const ComplexNumber& z)
^^^^^^^^^^^^^

但是你没有返回语句,这是undefined behavior,这意味着你不能依赖程序的行为,结果是不可预测的。看起来你应该有:

return output ;

在函数的末尾。我们可以从 C++ 标准草案6.6.3 返回语句第 2 段中看到这是未定义的行为:

[...] 从函数末尾流出相当于没有值的返回;这会导致值返回函数中的未定义行为。 [...]

【讨论】:

    【解决方案2】:

    函数声称返回一些东西:

    std::ostream& operator<<(std::ostream& output, const ComplexNumber& z)
    ^^^^^^^^^^^^^
    

    但最后没有return 声明。您应该添加一个:

    return output;
    

    【讨论】:

      【解决方案3】:

      这个函数

      std::ostream& operator<<(std::ostream& output,
                           const ComplexNumber& z)
      {
      output << "(" << z.mRealPart << " ";
      if (z.mImaginaryPart >= 0.0)
      {
          output << " + " << z.mImaginaryPart << "i)";
      }
      else
      {
          output << "- " << -z.mImaginaryPart << "i)";
      }
      } 
      

      有返回类型std::ostream &amp; 但是它什么也不返回。我觉得有错别字应该有

      std::ostream& operator<<(std::ostream& output,
                           const ComplexNumber& z)
      {
      output << "(" << z.mRealPart << " ";
      if (z.mImaginaryPart >= 0.0)
      {
          output << " + " << z.mImaginaryPart << "i)";
      }
      else
      {
          output << "- " << -z.mImaginaryPart << "i)";
      }
      
      return output;
      } 
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2014-04-20
        • 1970-01-01
        • 2018-10-23
        • 1970-01-01
        • 2012-10-24
        • 1970-01-01
        相关资源
        最近更新 更多