博客
关于我
类和对象的知识汇总
阅读量:458 次
发布时间:2019-03-06

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

C++ 类与函数重载

函数重载

函数重载是C++中的一项重要特性,允许在同一个类中定义多个方法,虽然它们的名字相同,但参数类型和个数可以不同。这样的重载主要基于以下两点:

  • 参数类型不同:如void func(int a)void func(double a)
  • 参数个数不同:如void func()void func(int a)
  • 类定义

    在C++中,类是程序中最基本的构建单位。类的定义需要遵循以下规则:

  • 数据成员的初始化

    • 静态数据成员可以在类体中显式初始化。
    • 非静态数据成员不能在类体中显式初始化,必须通过构造函数进行初始化。
  • 成员可以是其他类的对象

    • 类成员可以引用另一个类的对象,称为类的组合。
    • 但不能将类自身作为成员,避免循环引用。
  • 成员函数

    成员函数是类的一部分,用于操作类的内部状态。构造函数是最重要的成员函数,用于创建对象的过程。以下是构造函数的使用方法:

  • 对象声明

    类名 对象名[参数列表];
    类名 *指针变量 = new 类名[参数列表];
  • 构造函数的初始化

    构造函数可以通过函数体或初始化列表来初始化数据成员。以下是两种初始化方式:

    • 函数体初始化

      funname(参数列表) { 
      // 初始化逻辑
      }
    • 初始化列表

      funname(参数列表): 成员名1(形参名1),成员名2(形参名2),... {
      // 函数体,可以是空函数体
      }

      初始化列表的形式为:成员名1(形参名1),成员名2(形参名2),...

  • 必须使用初始化列表的情况

    • 数据成员为常量或引用类型时。
    • 数据成员为没有无参构造函数的类的对象时。
  • 析构函数

    析构函数是用于回收类对象的函数,自动被调用(隐式调用)。其特点如下:

    • 没有返回值。
    • 不能有参数。
    • 不能被重载。
    • 类外实现。

    析构函数的定义格式如下:

    class MyClass {
    public:
    ~MyClass() {
    // 析构函数体
    }
    };

    总结

    函数重载和类的定义是C++编程的核心概念。通过合理使用函数重载,可以让类的方法更加灵活。类的定义需要遵守数据成员的初始化规则,以及成员函数的编写规范。构造函数和析构函数的正确使用,能够确保类对象的创建和释放流程的正确性。

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

    你可能感兴趣的文章
    mySQL和Hive的区别
    查看>>
    MySQL和Java数据类型对应
    查看>>
    mysql和oorcale日期区间查询【含左右区间问题】
    查看>>
    MYSQL和ORACLE的一些操作区别
    查看>>
    mysql和redis之间互相备份
    查看>>
    MySQL和SQL入门
    查看>>
    mysql在centos下用命令批量导入报错_Variable ‘character_set_client‘ can‘t be set to the value of ‘---linux工作笔记042
    查看>>
    Mysql在Linux运行时新增配置文件提示:World-wrirable config file ‘/etc/mysql/conf.d/my.cnf‘ is ignored 权限过高导致
    查看>>
    Mysql在Windows上离线安装与配置
    查看>>
    MySQL在渗透测试中的应用
    查看>>
    Mysql在离线安装时启动失败:mysql服务无法启动,服务没有报告任何错误
    查看>>
    Mysql在离线安装时提示:error: Found option without preceding group in config file
    查看>>
    MySQL基于SSL的主从复制
    查看>>
    Mysql基本操作
    查看>>
    mysql基本操作
    查看>>
    mysql基本知识点梳理和查询优化
    查看>>
    mysql基础
    查看>>
    Mysql基础 —— 数据基础操作
    查看>>
    mysql基础---mysql查询机制
    查看>>
    MySQL基础5
    查看>>