C++类成员指针

46 篇文章 4 订阅

类成员指针

类成员指针是指可以指向类的非静态成员的指针。成员指针指向的是类的成员。类的静态成员不属于任何对象,因此无须特殊的静态成员的指针,指向静态成员的指针和普通函数指针没有什么区别。当初始化一个类成员指针时,令其指向类的某个成员,但是不指定该成员所属的对象,直到使用成员指针时,才提供成员所属的对象。

数据成员指针

类成员指针的使用*表示当前声明的名字是一个指针,但是在*之前必须添加className::表示当前定义的指针可以指向className的成员。例如:

const std::string Screen::*pData;//pdata可以指向一个常量(非常量)Screen对象的std::string成员

上述语句将pData声明成“一个指向Screen类的const std::string 成员的指针”。const对象的数据成员本身也是const的,pData声明为const std::string意味着可以指向任何Screen对象的一个成员,不管该Screen对象是否是cosnt的。但是使用pData只能读取它所指的成员,而不能向它写入数据。

初始化类成员指针:

pData = &Screen::contents;//取地址符&作用于Screen类的成员而非内存中的一个该类的对象。

用C++11语法声明类成员指针最简单的方法是使用auto或decltype:

auto pData = &Screen::contents;

类数据成员指针

例1:

#include <iostream>
#include <string>

class Person
{
public:
    const std::string name="1234";
};


int main(void)
{
    Person person1;
    Person* person2 = new Person();
    //str为指向Person对象的const string成员的指针
    //str指定了成员name,此时没有指向任何数据
    const std::string Person::*str = &Person::name;
    //使用对象实例解引用成员指针
    std::cout<< person1.*str <<std::endl;
    std::cout << person2->*str << std::endl;

    return 0;
}

运行结果如下:

例2:

#if 1

#include <iostream>
#include <memory>
#include <string>

class Person
{
public:
    const std::shared_ptr<std::string> name{std::make_shared<std::string>("1234")};
};


int main(void)
{
    Person person1;
    auto person2 = std::make_shared<Person>();
    //str为指向Person对象的const string成员的指针
    //str指定了成员name,此时没有指向任何数据
    const std::shared_ptr<std::string> Person::*str = &Person::name;
    //使用对象实例解引用成员指针
    std::cout<< *(person1.*str) <<std::endl;

    return 0;
}

运行结果如下:

 

例3:

#include<iostream>
#include <string>

class Person
{
public:
    const std::string name="1234";
    bool testFunc(int height)
    {
        std::cout << height << std::endl;
        return true;
    };
};


int main(void)
{

    bool (Person::*func)(int)=&Person::testFunc;
    Person person1;
    (person1.*func)(10);
    Person* person2 = new Person();
    (person2->*func)(20);
    system("pause");
    return 0;
}

运行结果如下:

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值