前向声明改变功能行为?
Forward decleration changes function behaviour?
我正在学习 C++,只是发现了一些我想了解的奇怪的东西(请参阅代码第 5 行的注释):
#include <iostream>
using namespace std;
// WITH this forward decleration the output is A=1 and B=2
// WITHOUT this forward decleration the output is A=2 and B=1
// WHY??
void swap(int a, int b);
int main() {
int a = 1;
int b = 2;
swap(a, b);
cout << "A: " << a << endl;
cout << "B: " << b << endl;
system("PAUSE");
return 0;
}
void swap(int a, int b) {
int tmp = a;
a = b;
b = tmp;
}
有人可以解释一下这种行为吗?我认为默认情况下,c++ 按值传递,除非你在函数参数前面使用 amperstand (&),如下所示:
function swap(int &a, int &b) {
您的 swap
实现在函数中本地交换值,因为它的参数是按值传递的。它不会改变调用函数中的任何内容。
当您没有该函数声明时,使用 std::swap
,这是正确的做法。
首先,您的交换函数不会交换原始参数。它交换将在退出函数后销毁的原始参数的副本。如果您希望该函数确实交换原始参数,则必须将参数声明为 referemces
void swap(int &a, int &b) {
int tmp = a;
a = b;
b = tmp;
}
当程序中没有函数的前向声明时,编译器似乎会选择交换原始参数的标准函数 std::swap
。由于 using 指令
,标准函数 std::swap
被编译器考虑
using namepsace std;
如果删除它并删除函数的前向声明,则编译器将发出错误。
当您的函数的前向声明存在时,编译器会选择您的函数,因为它是非模板函数的最佳匹配。
我正在学习 C++,只是发现了一些我想了解的奇怪的东西(请参阅代码第 5 行的注释):
#include <iostream>
using namespace std;
// WITH this forward decleration the output is A=1 and B=2
// WITHOUT this forward decleration the output is A=2 and B=1
// WHY??
void swap(int a, int b);
int main() {
int a = 1;
int b = 2;
swap(a, b);
cout << "A: " << a << endl;
cout << "B: " << b << endl;
system("PAUSE");
return 0;
}
void swap(int a, int b) {
int tmp = a;
a = b;
b = tmp;
}
有人可以解释一下这种行为吗?我认为默认情况下,c++ 按值传递,除非你在函数参数前面使用 amperstand (&),如下所示:
function swap(int &a, int &b) {
您的 swap
实现在函数中本地交换值,因为它的参数是按值传递的。它不会改变调用函数中的任何内容。
当您没有该函数声明时,使用 std::swap
,这是正确的做法。
首先,您的交换函数不会交换原始参数。它交换将在退出函数后销毁的原始参数的副本。如果您希望该函数确实交换原始参数,则必须将参数声明为 referemces
void swap(int &a, int &b) {
int tmp = a;
a = b;
b = tmp;
}
当程序中没有函数的前向声明时,编译器似乎会选择交换原始参数的标准函数 std::swap
。由于 using 指令
std::swap
被编译器考虑
using namepsace std;
如果删除它并删除函数的前向声明,则编译器将发出错误。
当您的函数的前向声明存在时,编译器会选择您的函数,因为它是非模板函数的最佳匹配。