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