内置类型支持流插入
 自定义类型不支持流插入
注意:运算符重载如果有两个操作数的时候,第一个为左操作数,第二个为右操作数
 而成员函数的第一个参数默认为this基类,而this参数又不能显式书写,所以没法改
 也就是说第一个操作数只能为基类对象,第二个操作数是传参的参数
所以,当流操作做运算符重载时:
 第一个参数为基类this
 第二个操作数自然为流
 所以,就导致了,流插入的第一个操作数为this,第二个操作数才是cout
 总之,第一个参数作为左操作数,第二个参数作为第二个操作数
 所以,如果看起来是将控制台流入我们的对象
 这是将之流运算符写在类内部成员函数的结果
但是这不符合我们的思维
 形成以上问题的本质是因为,作为成员函数重载,this指针占据了第一个参数
 导致类对象必须是左操作数
 而要解决这个问题
 很简单
 不要写在成类内部的成员函数即可
 也就是说,将之写成为全局函数
 但是,问题又来了
 全局函数意味着不在类内部
 但是流操作符重载的意义在于打印类对象的数据
 然而,类对象的数据是封装在类域内部的
 而且一般来说,其作用域是限定为私有的private
 所以,如果我们非要这样去书写,那就只有将之定义为pubilc共有
 但是这又涉及到一个数据安全的问题
 那么,怎么办?
 有两个解决方案:
 一是是用get和set成员函数获取和设置类数据
 二是使用友元声明:
 什么是友元声明?
 就是将一个全局函数的声明为friend
 一般的理解就是,我已经是你的朋友了,可以访问你的私有
 现在就可以解决参数顺序的问题
但是,以上的重载是不支持连续赋值的,连续赋值必须注意的一点是返回值
 一般来说,连续赋值是从右到左
 但是,现在的流插入的书写顺序是从左到右
 返回值得改成ostream流
 这样就可以支持连续赋值
流插入打印和printf的区别:
 在原来的C语言只能支持%d、%c、%f、%p等特定数据类型的打印
 只能打印内置类型
 但是,如果是自定义类型,就没办法打印
 如果非要用printf,只能一个数据一个数据的比对类型的进行输出
 而且,如果一个数据是私有限定
 还涉及到一个访问的问题
 总之,不好处理
 但是有了流插入之后
 就解决了所有自定义类型的打印问题
流提取:>>
 和上述流插入一样的逻辑
 但是第二个类对象的参数不能限定为const
 因为要从流中提取数据放到类对象里面,要改变值