博客
关于我
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中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>
mysql中的rbs,SharePoint RBS:即使启用了RBS,内容数据库也在不断增长
查看>>
mysql中的undo log、redo log 、binlog大致概要
查看>>
Mysql中的using
查看>>