模块化功能背后的逻辑
Logic behind modular function
我不明白为什么 mysteryfunction(y) 等于 40
当我 int mysteryFunction(int, int =2) 时。谁能给我解释一下?
最好的MM
#include <iostream>
using namespace std;
int mysteryFunction (int, int = 2);
int main()
{
int x = 10, y = 20;
cout << mysteryFunction (y);
}
int mysteryFunction (int x, int y)
{
return x * y;
}
在mysteryFunction()
的声明中,第二个参数的默认值是2
,所以如果你只用一个参数调用它,第二个参数y
将是2
.
因此 mysteryFunction(20)
与 mysteryFunction(20, 2)
基本相同,根据您的代码应该 return 20 * 2 = 40.
您可能对以下事实感到困惑:您传递给 mysteryFunction()
作为其第一个参数的变量被命名为 y
,与其定义中的第二个参数相同。但是,这些是完全不同的变量。事实上,如何称呼它们并不重要,只有 arguments/parameters 的位置很重要(如果考虑函数重载,还有它们的类型)。
在 mysteryFunction
的声明中,您为第二个参数指定了默认值 2。然后你只用 1 个参数调用它,这样默认值就用于第二个参数。所以 y=20 和 20 * 2 = 40。不要混淆变量名。 main
中的x
和y
与mysteryFunction
中的x
和y
无关
默认情况下,他们会假定 y 为 2,因此当您填写 int x 时,它会自动接受 (x,2)。
我不明白为什么 mysteryfunction(y) 等于 40 当我 int mysteryFunction(int, int =2) 时。谁能给我解释一下?
最好的MM
#include <iostream>
using namespace std;
int mysteryFunction (int, int = 2);
int main()
{
int x = 10, y = 20;
cout << mysteryFunction (y);
}
int mysteryFunction (int x, int y)
{
return x * y;
}
在mysteryFunction()
的声明中,第二个参数的默认值是2
,所以如果你只用一个参数调用它,第二个参数y
将是2
.
因此 mysteryFunction(20)
与 mysteryFunction(20, 2)
基本相同,根据您的代码应该 return 20 * 2 = 40.
您可能对以下事实感到困惑:您传递给 mysteryFunction()
作为其第一个参数的变量被命名为 y
,与其定义中的第二个参数相同。但是,这些是完全不同的变量。事实上,如何称呼它们并不重要,只有 arguments/parameters 的位置很重要(如果考虑函数重载,还有它们的类型)。
在 mysteryFunction
的声明中,您为第二个参数指定了默认值 2。然后你只用 1 个参数调用它,这样默认值就用于第二个参数。所以 y=20 和 20 * 2 = 40。不要混淆变量名。 main
中的x
和y
与mysteryFunction
x
和y
无关
默认情况下,他们会假定 y 为 2,因此当您填写 int x 时,它会自动接受 (x,2)。