8.2 指向类的静态成员的指针

对类的静态成员的访问不依赖于对象,可以用普通的指针来指向和访问。

//通过指针访问类的静态数据成员

#include <iostream>

using namespace std;

class Point //Point类声明

{

public:        //外部接口

         Point(int xx=0, int yy=0) {X=xx;Y=yy;countP++;}    //构造函数

         Point(Point &p); //拷贝构造函数

         int GetX() {return X;}

         int GetY() {return Y;}

 

         static int countP; //静态数据成员引用性说明

private:      //私有数据成员

         int X,Y;

};

Point::Point(Point &p)

{

         X=p.X;

         Y=p.Y;

         countP++;

}

 

int Point::countP=0;    //静态数据成员定义性说明

 

int main()   //主函数实现

{

         int *count=&Point::countP;              //声明一个int型指针,指向类的静态成员

         Point A(4,5);       //声明对象A

         cout<<"Point A,"<<A.GetX()<<","<<A.GetY();

         cout<<" Object id="<<*count<<endl;   //直接通过指针访问静态数据成员

         Point B(A); //声明对象B

         cout<<"Point B,"<<B.GetX()<<","<<B.GetY();

         cout<<" Object id="<<*count<<endl; //直接通过指针访问静态数据成员

}

//通过指针访问类的静态函数成员

#include <iostream>

using namespace std;

class Point //Point类声明

{

public:        //外部接口

         Point(int xx=0, int yy=0) {X=xx;Y=yy;countP++;}    //构造函数

         Point(Point &p); //拷贝构造函数

         int GetX() {return X;}

         int GetY() {return Y;}

         static void GetC() {cout<<" Object id="<<countP<<endl;}       //静态函数成员

private:      //私有数据成员

         int X,Y;

         static int countP; //静态数据成员引用性说明

};

Point::Point(Point &p)

{

         X=p.X;

         Y=p.Y;

         countP++;

}

 

int Point::countP=0;    //静态数据成员定义性说明

//初始化,使用类名限定

 

int main()   //主函数实现

{

         void (*gc)()=Point::GetC;     //声明一个指向函数的指针,指向类的静态成员函数

         Point A(4,5);       //声明对象A

         cout<<"Point A,"<<A.GetX()<<","<<A.GetY();

         gc();  //输出对象序号,直接通过指针访问静态数据成员

         Point B(A); //声明对象B

         cout<<"Point B,"<<B.GetX()<<","<<B.GetY();

         gc();  //输出对象序号,直接通过指针访问静态数据成员

}

分享:

 

C++——指针5的更多相关文章

  1. TODO:Golang指针使用注意事项

    TODO:Golang指针使用注意事项 先来看简单的例子1: 输出: 1 1 例子2: 输出: 1 3 例子1是使用值传递,Add方法不会做任何改变:例子2是使用指针传递,会改变地址,从而改变地址. ...

  2. enote笔记法使用范例(2)——指针(1)智能指针

    要知道什么是智能指针,首先了解什么称为 “资源分配即初始化” what RAII:RAII—Resource Acquisition Is Initialization,即“资源分配即初始化” 在&l ...

  3. C++虚函数和函数指针一起使用

    C++虚函数和函数指针一起使用,写起来有点麻烦. 下面贴出一份示例代码,可作参考.(需要支持C++11编译) #include <stdio.h> #include <list> ...

  4. C++11 shared_ptr 智能指针 的使用,避免内存泄露

    多线程程序经常会遇到在某个线程A创建了一个对象,这个对象需要在线程B使用, 在没有shared_ptr时,因为线程A,B结束时间不确定,即在A或B线程先释放这个对象都有可能造成另一个线程崩溃, 所以为 ...

  5. c 数组与指针的使用注意事项

    数组变量和指针变量有一点小小的区别 所以把数组指针赋值给指针变量的时候千万要小心 加入把数组赋值给指针变量,指针变量只会包含数组的地址信息 而对数组的长度一无所知 相当于指针丢失了一部分信息,我们把这 ...

  6. Marshal.Copy将指针拷贝给数组

    lpStatuss是一个UNITSTATUS*的指针类型实例,并包含SensorDust字段 //定义一个数组类型 byte[] SensorDust = new byte[30] //将指针类型拷贝 ...

  7. C++智能指针

    引用计数技术及智能指针的简单实现 基础对象类 class Point { public: Point(int xVal = 0, int yVal = 0) : x(xVal), y(yVal) { ...

  8. EC笔记:第三部分:17、使用独立的语句将newed对象放入智能指针

    一般的智能指针都是通过一个普通指针来初始化,所以很容易写出以下的代码: #include <iostream> using namespace std; int func1(){ //返回 ...

  9. 智能指针shared_ptr的用法

    为了解决C++内存泄漏的问题,C++11引入了智能指针(Smart Pointer). 智能指针的原理是,接受一个申请好的内存地址,构造一个保存在栈上的智能指针对象,当程序退出栈的作用域范围后,由于栈 ...

  10. 智能指针unique_ptr的用法

    unique_ptr是独占型的智能指针,它不允许其他的智能指针共享其内部的指针,不允许通过赋值将一个unique_ptr赋值给另一个unique_ptr,如下面错误用法: std::unique_pt ...

随机推荐

  1. springboot无法访问静态资源

    无法访问static下的静态资源 1.在application.yml中添加 resources: static-locations: classpath:/META-INF/resources/,c ...

  2. 如何在IDEA的maven项目中连接并使用MySQL8.0

    首先看一下我的基本的开发环境: 操作系统:MacOS 10.13.5 编辑器:IDEA 2018.3 其他:MySQL8.0.15.Maven 3.3.9.JDK 1.8 好,下面就正式开始: 第一步 ...

  3. 消息队列MQ(一)

    消息队列 为什么要用消息队列,都有什么优缺点? 要问的是消息队列都有哪些场景,然后项目里具体实现的什么场景,你在这个场景里用的什么消息队列? 期望的回答是,你们公司有个什么业务,这个业务场景有什么技术 ...

  4. Windows Server 2012 R2的安装(GUI桌面版本)

    镜像:cn_windows_server_2012_r2_x64_dvd_2707961.iso 1.将安装光盘插入服务器,开机会读取到Windows安装程序,点击下一步 2.点击现在安装     3 ...

  5. 802.11 MAC基础

    MAC(媒介访问控制层)位于各式物理层之上,控制数据的传输.它负责核心成帧操作以及与有线骨干网络之间的交互. 802.11采用载波监听多路访问/冲突避免(CSMA/CA)机制来控制对传输媒介的访问. ...

  6. Docker 安装 ELK

    安装 首先安装 Docker 与 Docker-Compose 相关的组件,我们这里直接使用准备好的 ELK 镜像,执行以下命令从 Dockerhub 上拉取指定版本的镜像,在本例当中我使用的是 7. ...

  7. 二次剩余的判定及Cipolla算法

    二次剩余 ppp是奇素数.所有的运算都是在群Zp∗Z_{p}^{*}Zp∗​中的运算.方程x2=a≠0x^2=a \neq 0x2=a̸​=0问是否有解,以及解是什么?若有解,aaa就是模ppp的二次 ...

  8. 当页面提交时,执行相关JS函数检查输入是否合法

    当页面提交时,执行相关JS函数检查输入是否合法 关键代码 <form action="tj.php" method="post" onSubmit=&qu ...

  9. CSS3中新增的对文本和字体的设置

    文字阴影 text-shadow: 水平偏移 垂直偏移  模糊 颜色 兼容性:IE10+ <!DOCTYPE html> <html lang="en" mani ...

  10. Java模拟客户端向服务器上传文件

    先来了解一下客户端与服务器Tcp通信的基本步骤: 服务器端先启动,然后启动客户端向服务器端发送数据. 服务器端收到客户端发送的数据,服务器端会响应应客户端,向客户端发送响应结果. 客户端读取服务器发送 ...