先看一段代码,如果不看后面的讲解,你就能看懂,那表明你已经明白了不同作用域的同名变量覆盖问题了。
这段小程序的输出结果是什么?
#include <iostream>
#include <vector>
typedef int INT4;
class Oops{};
Oops& operator< (Oops &ref1 , Oops &ref2){
std::cerr << "Amazing!" << std::endl;
return ref1;
}
Oops& operator> (Oops &ref1, Oops &ref2){
std::cerr << "Bazinga" << std::endl;
return ref2;
}
int main(){
Oops vector;
Oops INT4;
Oops foo;
vector<INT4> foo;
return 0;
}
在揭晓答案之前,我们先分析一下不同作用域的重名覆盖问题。在一个嵌套的作用域中,如果出现了同名的变量,那么局部的将覆盖大作用域中的变量名。
所以main函数中的vector、INT4、foo都是Oops类对象,而vector〈INT4是调用了重载运算符<,之后那个也是重载运算符>。
所以运行结果为:
Amazing!
Bazinga