博客
关于我
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 InnoDB事务隔离级别与锁机制深入解析
    查看>>
    Mysql InnoDB存储引擎 —— 数据页
    查看>>
    Mysql InnoDB存储引擎中的checkpoint技术
    查看>>
    Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
    查看>>
    MySQL InnoDB引擎的锁机制详解
    查看>>
    Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
    查看>>
    mysql InnoDB数据存储引擎 的B+树索引原理
    查看>>
    mysql innodb通过使用mvcc来实现可重复读
    查看>>
    mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
    查看>>
    Mysql join原理
    查看>>
    mysql order by多个字段排序
    查看>>
    MySQL Order By实现原理分析和Filesort优化
    查看>>
    mysql problems
    查看>>
    mysql replace first,MySQL中处理各种重复的一些方法
    查看>>
    MySQL replace函数替换字符串语句的用法(mysql字符串替换)
    查看>>
    Mysql Row_Format 参数讲解
    查看>>
    mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
    查看>>
    MySQL Server 5.5安装记录
    查看>>
    mysql slave 停了_slave 停止。求解决方法
    查看>>
    MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
    查看>>