构造函数不仅可以构造与初始化对象,对于单个参数的构造函数,还具有类型转换的作用。
class Date
{
public:Date(int year):_year(year){}explicit Date(int year):_year(year){}private:int _year;int _month:int _day; };
void TestDate()
{Date d1(2018);// 用一个整形变量给日期类型对象赋值// 实际编译器背后会用2019构造一个无名对象,最后用无名对象给d1对象进行赋值d1 = 2019;}
声明为static的类成员称为类的静态成员,用static修饰的成员变量,称之为静态成员变量;用static修饰的成员函数,称之为静态成员函数。静态的成员变量一定要在类外进行初始化。
this指针的意义:执行当前调用此函数的对象
static成员函数不包含隐藏的this指针
静态成员所有对象共享static函数可以通过类名访问,通过类名访问没有对象,this没有指向
static成员变量,必须在类外初始化
static———类当中的全局变量,也有public、protected、private3种访问级别,也可以具有返回值
cout<<c1._count<<endl;
cout<<A::_count<<endl;
友元提供了一种突破封装的方式,提供了便利。
问题:现在我们尝试去重载operator<<,然后发现我们没办法将operator<<重载成成员函数。因为cout的输出流对象和隐含的this指针在抢占第一个参数的位置。this指针默认是第一个参数也就是左操作数。但是实际使用中cout需要是第一个形参对象,才能正常使用。所以我们要将operator<<重载成全局函数。但是这样的话,又会导致类外没办法访问成员。
class Date
{
public:Date(int year, int month, int day): _year(year), _month(month), _day(day){}ostream& operator<<(ostream& _cout)//this指针默认是第一个参数也就是左操作数(即类的对象){_cout<<d._year<<"-"<<d._month<<"-"<<d._day;return _cout;}private:int _year;int _month;int _day
};
int main()
{
Date d(2017, 12, 24);d<<cout;//输出方式也不同于平常写法: cout<<d<<endl;return 0; }
class Date
{
//友元声明;为访问私有成员提供了可能;
friend ostream& operator<<(ostream& _cout, const Date& d);
friend istream& operator>>(istream& _cin, Date& d);
public:Date(int year, int month, int day): _year(year), _month(month), _day(day){}private:int _year;int _month;int _day;
};
ostream& operator<<(ostream& _cout, const Date& d) {//达到访问左操作数(形参对象)的目的_cout<<d._year<<"-"<<d._month<<"-"<<d._day;return _cout; }
istream& operator>>(istream& _cin, Date& d) {_cin>>d._year;_cin>>d._month;_cin>>d._day;return _cin; }
int main(){Date d;cin>>d;cout<<d<<endl;//正常输出的写法;return 0;}
友元类的所有成员函数都可以是另一个类的友元函数,都可以访问另一个类中的非公有成员。
好了到这里就结束了,欢迎大家来评论,共同进步!
本文发布于:2024-02-01 22:26:45,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170679760639835.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |