博客
关于我
c++之const修饰成员函数
阅读量:462 次
发布时间:2019-03-06

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

常函数与常对象的理解与应用

在C++编程中,常函数和常对象是非常重要的概念,尤其是在面对类和对象的封装性时,理解它们的使用和限制对于提高代码的质量至关重要。本文将从基本概念到实际应用,详细解析常函数和常对象的特点及使用方法。

常函数的定义与特点

常函数是指在类的成员函数后面加上const修饰的函数。这样的函数具有以下特点:

  • 不可修改对象状态:常函数不能改变对象的成员变量。例如,void showPerson() const;中的this指针是Person* const this;,意味着在函数内部,this的指向和值都不能被修改。

  • 特殊变量的处理:如果类中的成员变量是用mutable修饰的,即使是在常函数中,这些变量也可以被修改。例如,mutable int tmp;在常函数中可以通过this->tmp = 200;进行修改。

  • 函数参数的常性:常函数的参数也无法被修改。在void showPerson() const中,this指针既不能被重新赋值,也不能被修改。

  • 常函数的示例分析

    class Person {public:    int age;    mutable int tmp; // 用mutable修饰的特殊变量,可以在常函数中修改    void showPerson() const {        // this指针的本质是指针常数,指针的指向是不可以修改的        // 即Person* const this;        // 在函数后面加了const之后,变成const Person* const this        // 此时,既不可以修改指向,也不可以修改值        this->age = 100; // 语句会导致编译错误        this->tmp = 200; // 语句可以成功编译    }};

    在上面的代码中,showPerson()是常函数,this指针是Person* const this;。其中,this->age = 100;会导致编译错误,因为常函数不能修改成员变量;而this->tmp = 200;可以成功编译,因为tmp是用mutable修饰的特殊变量。

    常对象的定义与特点

    常对象是指在对象声明前面加上const修饰的对象。这样的对象具有以下特点:

  • 只能调用常函数:常对象不能调用普通的成员函数,只能调用常函数。例如,const Person p;创建了一个常对象,p.showPerson();可以调用常函数,但p.age = 10;会导致编译错误。

  • 特殊变量的处理:如果类中的成员变量是用mutable修饰的,即使在常对象中,这些变量也可以被修改。例如,const Person p;创建了一个常对象,p.tmp = 20;可以成功编译。

  • 对象状态的常性:常对象的this指针是Person* const this;,意味着对象的指向和值都不能被修改。

  • 常对象的示例分析

    void test() {    const Person p; // 常对象不能调用普通成员函数,只能调用常函数    // p.age = 10; // 语句会导致编译错误    p.tmp = 20; // 特殊变量,在常对象下也可以修改    p.showPerson(); // 常函数可以正常调用}

    在上面的代码中,test()函数创建了一个常对象pp.age = 10;会导致编译错误,因为常对象不能修改成员变量;而p.tmp = 20;可以成功编译,因为tmp是用mutable修饰的特殊变量。p.showPerson();是常函数,可以正常调用。

    编译错误与正确编译的对比

    在实际开发中,常函数和常对象的使用需要注意以下几点:

  • 成员函数的编译:在常函数中,普通成员函数的调用会导致编译错误。例如,void editAge() { this->age++; }在常函数中不能被调用。

  • 成员变量的编译:在常对象中,普通成员变量的修改会导致编译错误。例如,p.age = 10;在常对象中不能被修改。

  • 特殊变量的编译:在常函数和常对象中,mutable修饰的成员变量可以被修改。例如,p.tmp = 20;在常对象中可以成功编译。

  • 通过上述分析,可以看出,常函数和常对象的使用需要对成员函数和成员变量的可修改性有清晰的理解。理解这些概念有助于我们在代码中更好地实现对象的封装性和数据的安全性。

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

    你可能感兴趣的文章
    MySQL高级-视图
    查看>>
    nacos集群搭建
    查看>>
    Nessus漏洞扫描教程之配置Nessus
    查看>>
    Nest.js 6.0.0 正式版发布,基于 TypeScript 的 Node.js 框架
    查看>>
    Netpas:不一样的SD-WAN+ 保障网络通讯品质
    查看>>
    Netty WebSocket客户端
    查看>>
    Netty工作笔记0011---Channel应用案例2
    查看>>
    Netty工作笔记0014---Buffer类型化和只读
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
    查看>>
    Netty常见组件二
    查看>>
    netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
    查看>>
    Netty核心模块组件
    查看>>
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>
    Netty源码—6.ByteBuf原理二
    查看>>
    Netty源码—7.ByteBuf原理三
    查看>>