- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在编写一个积分计算器。我试图让 main.cpp 文件从 functions.h.cpp 文件中的函数类中读取函数。对于简单的情况,我有一个定义如下的函数:
double square(double aX)
{
return aX*aX;
}
当我将它包含在主文件中时,此函数可以工作,但当我尝试从主文件中调用它时它在函数文件中时它不想工作。这是我的代码:
Main.cpp
文件:
#include <iostream>
#include "IntegralCalculator.h"
#include "functions.h"
using namespace std;
int main()
{
IntegralCalculator Function(square);
Function.print();
}
如您所见,还有一个名为 IntegralCalculator
的类它实际上进行了积分的计算,尽管当函数定义包含在 main 中并且函数作为参数传递时,它应该没有错。 functions.h
文件定义如下:
#ifndef FUNCTIONS_H
#define FUNCTIONS_H
#include <iostream>
#include <cmath>
#include "IntegralCalculator.h"
class functions : public IntegralCalculator
{
public:
functions();
double square(double aX);
};
#endif
和 functions.cpp
文件定义如下:
#include <iostream>
#include <cmath>
#include "functions.h"
double functions::square(double aX)
{
return aX*aX;
}
我知道现在我不需要 <cmath>
库,尽管我在添加它们时需要它来实现更复杂的功能。
我试过在 main 中继承函数类,我也试过为函数类创建一个命名空间并定义函数,但是这些都没有用。当我去编译时,出现以下错误:
Main.cpp: In function ‘int main()’:
Main.cpp:9: error: ‘square’ was not declared in this scope
如果有人可以帮我解决这个问题。我尝试编写的这段代码比我的类(class)更高级,所以我不确定如何修复它,尽管我想以这种方式编写程序。
编辑:如果你好奇,我包括了 functions.h
和 functions.cpp
Makefile 中的文件。当我尝试将 square(double aX)
放入时,我遇到了同样的错误IntegralCalculator
中的定义类也是。
最佳答案
你的问题是,square
是一个成员函数 AKA 方法。换句话说,任何地方都没有普通符号 square
,它是 functions::square
。而且因为它不是一个静态方法,所以单独使用它没有任何意义,它总是需要一个相应的对象实例,而你没有,即使你有,也无法使用 IntegralCalculator
。
3 个解决方案,按照最简单、最接近您的问题、最好的顺序排列:
从构造函数声明中,将 square
移出类,使其成为全局函数:
在任何类之外的 functions.h 中:
double square(double aX);
在函数.cpp中
double square(double aX) {
return aX*aX;
}
main.cpp 中的用法:
IntegralCalculator Function(square);
或者使它成为静态方法(如果你使用像 Java 这样的语言,你必须这样做,它不允许“裸”函数,但不是真正的 C++ 方式):
在函数.h中:
class functions // inheriting IntegralCalculator removed as not needed
{
public:
static double square(double aX);
};
在 functions.cpp 中:
//static
double functions::square(double aX) {
return aX*aX;
}
然后你可以像这样将它传递给 main.cpp 中的`Function constructor:
IntegralCalculator Function(functions::square);
最后,也许是最好的解决方案,将以上两者的优点结合起来:将 square
放在命名空间中。所以 functions.h 变成了
namespace functions {
double square(double aX)
}
functions.cpp 变为
namespace functions {
double square(double aX) {
return aX*aX;
}
}
你仍然像这样在 main 中使用它:
IntegralCalculator Function(functions::square);
关于C++ 从头文件中调用函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15630293/
C语言sscanf()函数:从字符串中读取指定格式的数据 头文件: ?
最近,我有一个关于工作预评估的问题,即使查询了每个功能的工作原理,我也不知道如何解决。这是一个伪代码。 下面是一个名为foo()的函数,该函数将被传递一个值并返回一个值。如果将以下值传递给foo函数,
CStr 函数 返回表达式,该表达式已被转换为 String 子类型的 Variant。 CStr(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CSng 函数 返回表达式,该表达式已被转换为 Single 子类型的 Variant。 CSng(expression) expression 参数是任意有效的表达式。 说明 通常,可
CreateObject 函数 创建并返回对 Automation 对象的引用。 CreateObject(servername.typename [, location]) 参数 serv
Cos 函数 返回某个角的余弦值。 Cos(number) number 参数可以是任何将某个角表示为弧度的有效数值表达式。 说明 Cos 函数取某个角并返回直角三角形两边的比值。此比值是
CLng 函数 返回表达式,此表达式已被转换为 Long 子类型的 Variant。 CLng(expression) expression 参数是任意有效的表达式。 说明 通常,您可以使
CInt 函数 返回表达式,此表达式已被转换为 Integer 子类型的 Variant。 CInt(expression) expression 参数是任意有效的表达式。 说明 通常,可
Chr 函数 返回与指定的 ANSI 字符代码相对应的字符。 Chr(charcode) charcode 参数是可以标识字符的数字。 说明 从 0 到 31 的数字表示标准的不可打印的
CDbl 函数 返回表达式,此表达式已被转换为 Double 子类型的 Variant。 CDbl(expression) expression 参数是任意有效的表达式。 说明 通常,您可
CDate 函数 返回表达式,此表达式已被转换为 Date 子类型的 Variant。 CDate(date) date 参数是任意有效的日期表达式。 说明 IsDate 函数用于判断 d
CCur 函数 返回表达式,此表达式已被转换为 Currency 子类型的 Variant。 CCur(expression) expression 参数是任意有效的表达式。 说明 通常,
CByte 函数 返回表达式,此表达式已被转换为 Byte 子类型的 Variant。 CByte(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CBool 函数 返回表达式,此表达式已转换为 Boolean 子类型的 Variant。 CBool(expression) expression 是任意有效的表达式。 说明 如果 ex
Atn 函数 返回数值的反正切值。 Atn(number) number 参数可以是任意有效的数值表达式。 说明 Atn 函数计算直角三角形两个边的比值 (number) 并返回对应角的弧
Asc 函数 返回与字符串的第一个字母对应的 ANSI 字符代码。 Asc(string) string 参数是任意有效的字符串表达式。如果 string 参数未包含字符,则将发生运行时错误。
Array 函数 返回包含数组的 Variant。 Array(arglist) arglist 参数是赋给包含在 Variant 中的数组元素的值的列表(用逗号分隔)。如果没有指定此参数,则
Abs 函数 返回数字的绝对值。 Abs(number) number 参数可以是任意有效的数值表达式。如果 number 包含 Null,则返回 Null;如果是未初始化变量,则返回 0。
FormatPercent 函数 返回表达式,此表达式已被格式化为尾随有 % 符号的百分比(乘以 100 )。 FormatPercent(expression[,NumDigitsAfterD
FormatNumber 函数 返回表达式,此表达式已被格式化为数值。 FormatNumber( expression [,NumDigitsAfterDecimal [,Inc
我是一名优秀的程序员,十分优秀!