博客
关于我
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中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>