博客
关于我
C++类的构造函数
阅读量:673 次
发布时间:2019-03-16

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

1 常规写法

在C++编程中,类的构造函数是类对象创建的入口。以下是一个常规的定义方法:

class Student {private:    string _name;    char _sex;    int _age;public:    Student(string name, char sex, int age) {        _name = name;        _sex = sex;        _age = age;    }};

这个代码中,构造函数通过将参数赋值给对应的成员变量来初始化对象。这种写法直观简单,但在变量较多时可能显得冗长。

2 初始化列表赋值方法

为了提高代码的可读性,特别是在类成员较多时,C++提供了初始化列表的写法:

class Student {private:    string _name;    char _sex;    int _age;public:    Student(string name, char sex, int age) : _name(name), _sex(sex), _age(age) {    }};

在这个例子中,构造函数的实现部分简化为一行语句 _name(name), _sex(sex), _age(age)。这种写法的意义在于直接将初始化列表中的值赋给对应的成员变量,而无需在函数体中逐一写出赋值语句。

需要注意的点:

  • 写法简便:初始化列表赋值在变量较多时特别方便,直接明了,减少了赋值语句的数量。
  • 灵活应用:可以选择性地初始化部分成员变量,而不是全部。
  • 初始化顺序无关:成员变量的初始化顺序遵循类中定义的顺序,与初始化列表中的顺序无关。
  • 这种写法虽然不会提高效率,但在代码可读性方面起着重要作用。正确使用初始化列表可以提升代码的质量和可维护性。在实际编码中,根据具体需求选择合适的赋值方式以达到最佳效果。

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

    你可能感兴趣的文章
    mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
    查看>>
    MYSQL:基础——3N范式的表结构设计
    查看>>
    MYSQL:基础——触发器
    查看>>
    Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
    查看>>
    mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
    查看>>
    mysqldump 参数--lock-tables浅析
    查看>>
    mysqldump 导出中文乱码
    查看>>
    mysqldump 导出数据库中每张表的前n条
    查看>>
    mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
    查看>>
    Mysqldump参数大全(参数来源于mysql5.5.19源码)
    查看>>
    mysqldump备份时忽略某些表
    查看>>
    mysqldump实现数据备份及灾难恢复
    查看>>
    mysqldump数据库备份无法进行操作只能查询 --single-transaction
    查看>>
    mysqldump的一些用法
    查看>>
    mysqli
    查看>>
    MySQLIntegrityConstraintViolationException异常处理
    查看>>
    mysqlreport分析工具详解
    查看>>
    MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
    查看>>
    Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
    查看>>
    mysql_real_connect 参数注意
    查看>>