虚表指针初始化顺序

无继承时:

1、分配内存
2、初始化列表之前赋值虚表指针
3、列表初始化
4、执行构造函数体

有继承时:

1、分配内存
2、基类构造过程(按照无继承来)
3、初始化子类虚表指针
4、子类列表初始化
5、执行子类构造函数体

Q:虚表指针在初始化列表之前被赋值,可以放在初始化列表之后赋值吗?即顺序是:列表初始化、虚表指针赋值、构造函数体??

class B
{
public:
	virtual int size(){return 0;}
};


class A:public B{
public:
	int m_a; 
	A():m_a(size())   //在初始化列表中调用了虚函数(应该是A类的size()函数,不应该是B类的size()函数)
	{
		cout<<m_a<<endl;
	}
	virtual int size(){
		//cout<<2<<endl;
		return 1;}
};

int main()
{
	A a;
	return 0;
}

解答:如果虚表指针的初始化在初始化列表之后的话,可能会出现如上代码所示的情况:也就是说,在初始化列表中使用了一个虚函数!!!
那么在调用此虚函数的时候,应该访问哪个虚表呢?是基类的虚表?还是当前类的虚表?

毫无疑问,应该是当前类的虚表!!!
但是在调用此虚函数的时候,虚表指针并未赋值为子类的虚表,所以无法访问当前类的虚函数,访问的依旧是基类的虚函数。

因此,将虚表指针的赋值过程应该放置在初始化列表之前,这是为了防止在初始化列表出现调用虚函数的情况!!!

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我来回答你的问题。 首先,让我们来介绍一下顺序表。顺序表是一种线性表,它利用一段地址连续的存储单元依次存储线性表的数据元素,数据元素之间的逻辑关系由它们的物理位置来表示。 接下来,我们来看一下如何创建和初始化一个顺序表。 1. 创建顺序表 创建顺序表需要进行以下几个步骤: (1)定义一个结构体来表示顺序表,结构体中需要包含顺序表的元素个数和存储数据的数组。 (2)定义一个指向顺序表结构体的指针变量,用于指向新创建的顺序表。 (3)动态分配内存空间,将指针变量指向分配的内存地址。 (4)对顺序表的元素个数进行初始化。 下面是一个示例代码: ``` // 定义顺序表结构体 typedef struct { int *data; // 存储数据的数组 int length; // 元素个数 } SeqList; // 创建顺序表 SeqList* creatSeqList(int size) { SeqList* L = (SeqList*)malloc(sizeof(SeqList)); L->data = (int*)malloc(size * sizeof(int)); L->length = 0; return L; } ``` 上述代码中,我们创建了一个指向 SeqList 结构体的指针变量 L,然后动态分配了内存空间,将 L 指向该空间,并对顺序表的元素个数进行了初始化。 2. 初始化顺序初始化顺序表需要进行以下几个步骤: (1)定义一个数组,用于存储需要初始化的元素数据。 (2)计算数组的长度,以便进行遍历和赋值。 (3)对顺序表的元素进行赋值。 下面是一个示例代码: ``` // 初始化顺序表 void initSeqList(SeqList* L, int a[], int n) { for (int i = 0; i < n; i++) { L->data[i] = a[i]; L->length++; } } ``` 上述代码中,我们传入了一个指向 SeqList 结构体的指针变量 L,一个需要初始化的数组 a,以及数组的长度 n。然后,我们通过遍历数组 a 的方式,将其中的元素依次赋值给顺序表 L 中的 data 数组,并且对顺序表的元素个数进行累加。这样,我们就成功地初始化顺序表。 希望这个回答能够帮到你,如果你还有其他问题,可以继续问我哦。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值