sizeof emtpy c

文章讨论了在不同类层次结构中,当类A从B派生且C从A派生时,共享VPTR导致C的大小;反之,如果C从两个基类A和B派生,每个基类都有虚拟函数,则C将有两个VPTR,总大小是两个VPTR的和。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

In a class hierarchy where A is derived from B, and C is derived from A, all having virtual functions, A and C would share the same VPTR as they are in the same class hierarchy. Therefore, the size of C would be the size of a single VPTR, which is typically 8 bytes on a 64-bit platform.

On the other hand, when a class C is derived from two parent classes A and B, and both A and B have a virtual function, C would have two VPTRs - one for each class hierarchy. Therefore, the size of C would be the sum of the sizes of the VPTRs for A and B, which is typically 16 bytes on a 64-bit platform.

/************************************************************* date: April 2017 copyright: Zhu En DO NOT distribute this code without my permission. **************************************************************/ // 循环顺序的队列实现文件 ///////////////////////////////////////////////////////// #include <stdio.h> #include <stdlib.h> #include "SeqQueue.h" SeqQueue* SQ_Create(int maxlen) // 创建顺序队列, 队列最多存储maxlen个队列元素。 { SeqQueue* sq=(SeqQueue*)malloc(sizeof(SeqQueue)); sq->data=(T*)malloc(sizeof(T)*(maxlen+1)); sq->front=sq->rear=0; sq->max=maxlen+1; return sq; } void SQ_Free(SeqQueue* sq) // 释放队列空间,以删除队列。 { free(sq->data); free(sq); } void SQ_MakeEmpty(SeqQueue* sq) // 将队列置空。 { sq->front=0; sq->rear=0; } bool SQ_IsEmpty(SeqQueue* sq) // 判断队列是否为空,为空返回true,否则返回false。 { // 请在Begin-End之间补充代码,完成队列是否为空的判断。 /********** Begin *********/ /********** End **********/ } bool SQ_IsFull(SeqQueue* sq) // 判断队列是否为满。为满返回true,否则返回false。 { // 请在Begin-End之间补充代码,完成队列是否为满的判断。 /********** Begin *********/ /********** End **********/ } int SQ_Length(SeqQueue* sq) // 队列长度。 { // 请在Begin-End之间补充代码,获取队列长度。 /********** Begin *********/ /********** End **********/ } bool SQ_In(SeqQueue* sq, T x) // 将x入队。若入队失败(队列满),则返回false,否则返回true。 { // 请在Begin-End之间补充代码,将 x 入队。 /********** Begin *********/ /********** End **********/ } bool SQ_Out(SeqQueue* sq, T& item) // 从队列sq出队一个元素,返回时item为出队的元素的值。若出队成功(队列不为空),则返回true,否则(队列空),返回false,此时item不会返回有效值。 { // 请在Begin-End之间补充代码,完成元素出队操作。 /********** Begin *********/ /********** End **********/ } bool SQ_Head(SeqQueue* sq, T& head) // 获取队列头结点元素,返回时head保存头结点元素。 // 若获取失败(队列空),则返回值为false,否则返回值为true。 { if ( SQ_IsEmpty(sq) ){ return false; } else { head = sq->data[sq->front]; return true; } } void SQ_Print(SeqQueue* sq) // 依次打印出队列中的每个元素。 { int i=sq->front; if (SQ_IsEmpty(sq)) { printf("queue is emtpy")
03-30
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值