博客
关于我
c++基础——类的大小
阅读量:490 次
发布时间:2019-03-06

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

C++类大小分析

在C++编程中,类的大小计算是一个常见但容易引起混淆的问题。本文将通过一个实例详细分析类的大小计算规则,并探讨如何影响类的大小。

实例代码

#include 
using std::cout;using std::endl;class Father {private: int age;public: void showAge() { cout << "Age: " << age << endl; }};class Mother {};class Son : public Father {};class Sister : public Father {private: static int a;};int main() { cout << "Size of int : " << sizeof(int) << endl; cout << "Size of Father: " << sizeof(Father) << endl; cout << "Size of Mother: " << sizeof(Mother) << endl; cout << "Size of Son : " << sizeof(Son) << endl; cout << "Size of Sister: " << sizeof(Sister) << endl; return 0;}

执行结果分析

  • 类的大小与方法无关

    • int的大小为4字节,Father类的大小也为4字节。
    • Mother类为空类,大小为1字节。
    • Son类继承自Father,大小仍为4字节。
    • Sister类同样继承自Father,但添加了一个静态变量a,静态变量不占用类大小。
  • 空类的大小

    • 一个空类的大小始终是1字节,而不是0。
  • 继承与私有变量

    • 子类SonSister包含父类Father的私有变量age,但子类的大小与父类相同。
    • 静态变量不占用类大小,Sister类的静态变量a不会影响类的大小。
  • 虚函数的影响

    Father类中的showAge()改为虚函数:

    class Father {private:	int age;public:	virtual void showAge() {		cout << "Age: " << age << endl;	}};

    此时,Father类的大小增加了4字节。这是因为虚函数引入了一个指向虚函数表的指针,大小为4字节。

    总结

    • 类的大小主要由其成员变量和非静态成员函数决定。
    • 空类的大小始终为1字节。
    • 虚函数的引入会增加类的大小,增加的字节数等于指针的大小(通常为4字节)。

    通过以上分析,可以清晰地理解C++类大小计算的规则及其影响。

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

    你可能感兴趣的文章
    oracle中sql的case语句运用--根据不同条件去排序!
    查看>>
    Oracle中Transate函数的使用
    查看>>
    oracle中关于日期问题的汇总!
    查看>>
    Oracle中常用的语句
    查看>>
    Oracle中序列的操作以及使用前对序列的初始化
    查看>>
    oracle中新建用户和赋予权限
    查看>>
    Oracle中的NVL,NVL2,NULLIF以及COALESCE函数使用
    查看>>
    Oracle中的rownum 和rowid的用法和区别
    查看>>
    oracle中的大小写、字符、dual、数字、处理、日期、函数、显/隐式、时间、条件表达式case、decode、to_date、to_char、sysdate
    查看>>
    oracle中表和视图的区别,oracle中常用表和视图
    查看>>
    oracle从备份归档日志的方法集中回收
    查看>>
    oracle优化器analyzed,Oracle 学习之 性能优化(十三) 索引
    查看>>
    Oracle修改字段类型
    查看>>
    Oracle修改表或者字段的注释
    查看>>
    oracle典型安装失败,安装oracle 10失败
    查看>>
    Oracle内存结构详解(四)--Oracle SGA其他组成部分
    查看>>
    Oracle函数与存储过程和程序包
    查看>>
    Oracle分析函数之LEAD和LAG
    查看>>
    Oracle分组取前n条记录
    查看>>
    Oracle创建database link(dblink)和同义词(synonym)
    查看>>