下面的最终结果证明了这一点,
changed方法:由于调用方法只是将实参赋值给形参,所以当仅仅左值(形参)是一个变量时,等于新创建了一个变量,所以最终不会改变到右值(实参)的值,所以changed方法并没有改变两个实参的值
changedAnd方法:由于左值(形参)是一个引用,他其实代表的是实参,所以理所应当形参改变了实参跟着改变,因为他们是引用关系,代表同一个变量。
#include
<iostream>
using
namespace
std;
void
changedAnd(
int
&
a
,
int
&
b
);
void
changed(
int
a
,
int
b
);
int
test2() {
int
a = 0;
int
b = 1;
cout
<<
"begin--a:"
<<
a
<<
",b:"
<<
b
<<
endl;
changedAnd(a, b);
/*最终结果为:a=1,b=0 ,结果是两个的值调换了*/
//changed(a, b); /*最终结果为:a=0,b=1 ,结果并没有改变*/
cout
<<
"end--a:"
<<
a
<<
",b:"
<<
b
<<
endl;
return
0;
}
void
changedAnd(
int
&
a
,
int
&
b
) {
int
temp =
a
;
a
=
b
;
b
= temp;
}
void
changed(
int
a
,
int
b
) {
int
temp =
a
;
a
=
b
;
b
= temp;
}