本文学习自 狄泰软件学院 唐佐林老师的 C++课程
实验1 :逗号表达式回顾
实验2:重载逗号操作符
实验3:重载逗号操作符的陷阱,逗号操作符重载没啥意义
实验4:使用原生的逗号操作符足够

实验1 :逗号表达式回顾
#include <iostream>
#include <string>
using namespace std;
void func(int i)
{
cout << "func() : i = " << i << endl;
}
int main()
{
//数组 逗号表达式 最后一个表达式的值有效
/*正确的初始化方式:
int a[3][3] = {
{0, 1, 2},
{3, 4, 5},
{6, 7, 8}
};
*/
int a[3][3] = {
(0, 1, 2),
(3, 4, 5),
(6, 7, 8)
};
int i = 0;
int j = 0;
//逗号表达式
while( i < 5 )
func(i),
i++;
for(i=0; i<3; i++)
{
for(j=0; j<3; j++)
{
cout << a[i][j] << endl;
}
}
//左值是逗号表达式,最终为 j 等价于 j=6
(i, j) = 6;
cout << "i = " << i << endl;
cout << "j = " << j << endl;
return 0;
}
mhr@ubuntu:~/work/c++$
mhr@ubuntu:~/work/c++$ g++ 39-1.cpp
mhr@ubuntu:~/work/c++$ ./a.out
func() : i = 0
func() : i = 1
func() : i = 2
func() : i = 3
func() : i = 4
2
5
8
0
0
0
0
0
0
i = 3
j = 6
mhr@ubuntu:~/work/c++$

由于返回类型是 引用 所以要对b 去只读属性。
实验2:重载逗号操作符
#include <iostream>
#include <string>
using namespace std;
class Test
{
int mValue;
public:
Test(int i)
{
mValue = i;
}
int value()
{
return mValue;
}
};
Test& operator , (const Test& a, const Test& b)
{
return const_cast<Test&>(b);//返回值是最后有一个子表达式的值 去只读属性
}
Test func(Test& i)
{
cout << "func() : i = " << i.value() << endl;
return i;
}
int main()
{
Test t0(0);
Test t1(1);
Test tt = (t0, t1); // Test tt = t1;
cout << tt.value() << endl; // 1
return 0;
}
mhr@ubuntu:~/work/c++$ g++ 39-2.cpp
mhr@ubuntu:~/work/c++$ ./a.out
1
mhr@ubuntu:~/work/c++$
实验3:重载逗号操作符的陷阱
#include <iostream>
#include <string>
using namespace std;
class Test
{
int mValue;
public:
Test(int i)
{
mValue = i;
}
int value()
{
return mValue;
}
};
Test& operator , (const Test& a, const Test& b)
{
return const_cast<Test&>(b);
}
Test func(Test& i)
{
cout << "func() : i = " << i.value() << endl;
return i;
}
int main()
{
Test t0(0);
Test t1(1);
//等价于 operator , (func(t0), func(t1)) ,此时参数是函数体,参数的要先计算出来,并且计算顺序不一定,func(t0), func(t1)都会被执行。
Test tt = (func(t0), func(t1));
cout << tt.value() << endl; // 1
return 0;
}
mhr@ubuntu:~/work/c++$ g++ 39-2.cpp
mhr@ubuntu:~/work/c++$ ./a.out
func() : i = 1
func() : i = 0
1
mhr@ubuntu:~/work/c++$
分析,虽然结果是我们想要的,但是中间过程出错了,逗号表达式 变成了从右向左调用了,违背了原生的逗号表达式的语义。

实验4:使用原生的逗号操作符
#include <iostream>
#include <string>
using namespace std;
class Test
{
int mValue;
public:
Test(int i)
{
mValue = i;
}
int value()
{
return mValue;
}
};
/*
Test& operator , (const Test& a, const Test& b)
{
return const_cast<Test&>(b);
}
*/
Test func(Test& i)
{
cout << "func() : i = " << i.value() << endl;
return i;
}
int main()
{
Test t0(0);
Test t1(1);
Test tt = (func(t0), func(t1)); // Test tt = func(t1);
cout << tt.value() << endl; // 1
return 0;
}
mhr@ubuntu:~/work/c++$ g++ 39-2.cpp
mhr@ubuntu:~/work/c++$ ./a.out
func() : i = 0
func() : i = 1
1
mhr@ubuntu:~/work/c++$
结果是 逗号表达式中是从左向右执行,原生的逗号表达式完全可以满足我们的需要,所以重载逗号表达式完全是多此一举,还会出错。


本文通过四个实验深入探讨了C++中的逗号表达式,包括其基本用法、重载操作符的陷阱及原生操作符的有效性。实验展示了逗号表达式的语法特性,重载逗号操作符可能导致的问题,以及为何原生逗号操作符通常已足够满足需求。

244

被折叠的 条评论
为什么被折叠?



