1.首先对标准输入输出符号的重载,如果不定义为友元函数,而是定义为Class Test 类的成员函数
std::ostream& operator<<(std::ostream& os);
obj是Test的对象,那调用格式就成了obj<<std::cout;这样就和使用惯例和常例不符,而且也不能链式使用std::cout<<obj<<obj<<obj<<std::endl;这里顺便再提一下,为什么 operator<<要返回std::ostream&,而不能返回void,如
void operator<<(std::ostream& os);
如果返回void的话,就不能链式使用std::cout<<obj<<obj<<obj<<std::endl;只能使用std::cout<<obj;
2.其次对于赋值运算符“=”,如果类没有重载“=”的话,类会自动生成一个默认的赋值操作符,当进行同类(Test类)对象A=B操作时,编译器会自动调用默认的赋值操作将B的数据拷贝到A中。如Test类中有指针类型的成员变量,这时就存在两个指针指向同一块内存区域的问题。所有我们要对赋值运算符进行重载。那如果我们把运算符重载为友元函数,这样一些非左值(如常量)会被编译器隐式转换为一个临时对象,这样非左值就出现在了等号的左边,但编译器不会认为它出错,但这样破坏了“="的语义。比如定义了
friend int operator=(int a, integer b);
则2=a表述也正确,但却是明显的语法错误。

