博客
关于我
C++ 极简总结——类(二)
阅读量:253 次
发布时间:2019-03-01

本文共 1479 字,大约阅读时间需要 4 分钟。

类的静态成员<>

将要共享的数据说明为类的静态成员。静态成员是指声名为static的类的成员,包括静态数据成员和静态成员函数,在类的范围内所有对象共享该数据

静态数据成员

静态数据成员不属于任何对象,它不因对象的建立而产生,也不因对象的析构而删除,是类的一部分。

特点:

  1. 必须对静态数据成员进行初始化,系统分配具体的存储空间。
  2. 初始化不可以在构造函数中进行。
  3. 初始化格式:
    <数据类型><类名>::<变量名> = <初值>
#include 
using namespace std;class Point{ public: static int point_count; Point(int x = 0, int y = 0); ~Point();private: int _x; int _y;};Point::Point(int x , int y ){ _x = x; _y = y; point_count++; cout<<"Constructor"; cout<<"Point_Num = "<
<

静态成员函数

静态成员函数的定义和其他成员函数一样,静态成员函数与静态数据成员类似,属于类本身。在函数定义前加static 关键字。

静态成员函数的主要作用是用来访问同类中的静态成员,维护对象之间共享的数据。

#include 
using namespace std;class Point{ public: Point(int x = 0, int y = 0); ~Point(); static void show_count();private: int _x; int _y; static int point_count;};void Point::show_count(){ cout<<"Point Num = "<
<

类的友元

有时候需要普通函数直接访问一个类的保护或者私有数据成员。友元是C++提供给外部的类或者函数访问类的私有成员和保护成员的另一种途径。友元可以是一个函数,称为友元函数,也可以是一个类,称为友元类

友元函数

在类里声名一个普通函数,加上关键字friend,就成了该类的友元函数,它可以访问该类的一切成员。

函数原型:
friend <类型><函数名>(参数)

#include 
#include
using namespace std;class Point{ public: Point(int x = 0, int y = 0); ~Point(); friend double pointDistance(const Point a,const Point b); static void show_count();private: int _x; int _y; static int point_count;};void Point::show_count(){ cout<<"Point Num = "<
<

友元类

一个类也可以被声明为类一个类的友元,该类称为友元类。

假设有类A,类B,在类B的定义中将类A声名为友元,那么类A被称为类B的友元类,它所有的成员函数都可以访问类B中的任意成员。

友元的主要作用是为了提高效率和方便编程,但是友元在一定程度破坏了类的整体性,也破坏了封装性。

转载地址:http://jnrx.baihongyu.com/

你可能感兴趣的文章
mysql长事务
查看>>
mysql问题记录
查看>>
mysql间隙锁
查看>>
MySQL集群解决方案(1):MySQL数据库的集群方案
查看>>
MySQL集群解决方案(2):主从复制架构
查看>>
MySQL集群解决方案(4):负载均衡
查看>>
MySQL集群解决方案(5):PXC集群
查看>>
MySQL面试宝典
查看>>
WAP短信:融合传统短信和互联网的新型通信方式
查看>>
mysql面试题学校三表查询_mysql三表查询分组后取每组最大值,mysql面试题。
查看>>
Mysql面试题精选
查看>>
MySQL面试题集锦
查看>>
mysql面试题,存储引擎InnoDB和MyISAM
查看>>
mysql面试题:为什么MySQL单表不能超过2000W条数据?
查看>>
mysql面试题:创建索引时会不会锁表?
查看>>
mysql面试题:高度为3的B+树可以存放多少数据?
查看>>
mysql颠覆实战笔记(八)--mysql的自定义异常处理怎么破
查看>>
mysql驱动、durid、mybatis之间的关系
查看>>
mysql驱动支持中文_mysql 驱动包-Go语言中文社区
查看>>
MySQL高可用之——keepalived+互为主从
查看>>