此代码的运行思路是什么

我认为此程序的运行结果与真实的结果有偏差,我认为结果为
调用基类Base2的构造函数:2
调用基类Base1的构造函数:3
调用基类Base2的构造函数:1
调用基类Base1的构造函数:4

img

多继承时,构造函数的调用顺序跟class A:public Base1,public Base2这里有关,谁在前面就先调用谁。子类构造函数,根据继承顺序,在参数列表中找完一遍后,如果参数列表中还有父类参数,继续重新查找!!一直到找完所有父类相关的参数。
所以,这个题目中A obj(1,2,3,4)的调用顺序是:
(1)先找Base1(int i),在参数列表中首先找到Base1(c),所以显示 "调用基类Base1的构造函数:3"
(2)在找Base2(int j),在参数列表中首先找到Bas32(b),所以显示 "调用基类Base2的构造函数:2"
(3)子类构造函数中还有参数,继续找Base1,找到的是b1(d),所以显示 "调用基类Base1的构造函数:4"
(4)子类构造函数中还有参数,再找Base2,找到的是b2(a),所以显示 "调用基类Base2的构造函数:1"

  • 这篇博客: 常见加密算法总结-base系列部分中的 字典一 部分也许能够解决你的问题, 你可以仔细阅读以下内容或跳转源博客中阅读:
  • 2^5+1 = 33 个元素

    Base32还提供了另外一种字典定义,即Base32十六进制字母表。Base32十六进制字母表是参照十六进制的计数规则定义,两种字典没有本质的区别,只是字典不同而已。

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632