函数重载 只能通过范围和参数来区分。
const引用的问题,那就是非const首选是左值,const首选是右值.
如果上面的那个例子里面再加int foo(int),那么两个函数调用都将不能得到最好的匹配从而导致编译错误.
编译通不过!!!
t.cpp: In function `int main(int, char**)':
t.cpp:17: call of overloaded `A(int)' is ambiguous
t.cpp:5: candidates are: A::A(const A&) <near match>
t.cpp:13: A::A(int, int = 0)
t.cpp:10: A::A(int)
在使用缺省参数时必须记住两条规则。
第一条:只有参数列表后部参数才可是缺省的,也就是说,我们不可以在一个缺省参数后面又跟一个非缺省参数。
第二条:一旦使用了缺省参数,那么其后面的所有参数都必须是缺省的。
另外缺省参数只能放在函数声明中。
const引用的问题,那就是非const首选是左值,const首选是右值.
#include<iostream>
using namespace std;
int foo(int& );
int foo(const int& );
int foo(int & i){
cout<<"int & i:"<<i<<endl;
return i;
}
int foo(const int & i){
cout<<"const int & i:"<<i<<endl;
return 0;
}
int main(int argc,char **argv)
{
int t=foo(1);//选择const int&
int t1=foo(t);//选择int&
}
如果上面的那个例子里面再加int foo(int),那么两个函数调用都将不能得到最好的匹配从而导致编译错误.
#include <iostream>
using namespace std;
class A{
A(int i);
A(int i,int j=0);
};
A::A(int i){
cout<<"i:"<<i<<endl;
}
A::A(int i,int j){
cout<<"i:"<<i<<"j:"<<j<<endl;
}
int main(int argc,char **argv){
A a(100);
return 0;
}
编译通不过!!!
t.cpp: In function `int main(int, char**)':
t.cpp:17: call of overloaded `A(int)' is ambiguous
t.cpp:5: candidates are: A::A(const A&) <near match>
t.cpp:13: A::A(int, int = 0)
t.cpp:10: A::A(int)
在使用缺省参数时必须记住两条规则。
第一条:只有参数列表后部参数才可是缺省的,也就是说,我们不可以在一个缺省参数后面又跟一个非缺省参数。
第二条:一旦使用了缺省参数,那么其后面的所有参数都必须是缺省的。
另外缺省参数只能放在函数声明中。