函数打印奇怪的值.C++
Function printing strange values. C++
考虑这个例子:
class A
{
public:
int a;
public:
A():a(1){};
};
class B:public A
{
public:
int b;
public:
B():b(2){};
};
void print(A* a)
{
for(int i=0; i<10; ++i)
{
cout<<a[i].a<<" ";
}
}
int main()
{
B b[10];
print(b);
}
我的程序输出是:1 2 1 2 1 2 1 2 1 2 1 2.
但是它是如何通过 a[i].a 访问数据 b 的,因为我从未在输出中提到过 b。
问题是sizeof(A) != sizeof(B)
.
print
函数认为它(基本上)有一个A
对象的数组。它对B
或其成员一无所知。
虽然B
是A
,但B[]
不是A[]
。
有三种自然方法可以解决您的问题:
- 让
print
接受B*
论点。 - 使
print
成为模板函数。 - 创建采用
B*
参数的重载print
。
选择哪一个取决于您,并取决于您的用例。
为什么您似乎从B
打印值是因为内存布局。
A
数组在内存中如下所示:
+--------+--------+--------+--------+--------+--------+--------+-----+ |A[0].a |A[1].a |答[2].a |A[3].a |答[4].a |答[5].a |A[6].a |... | +--------+--------+--------+--------+--------+--------+--------+-----+
一组B
看起来像这样
+--------+--------+--------+--------+--------+--------+--------+-----+ |B[0].a |B[0].b |B[1].a |B[1].b |B[2].a |B[2].b |B[3].a |... | +--------+--------+--------+--------+--------+--------+--------+-----+
现在,如果我们将两个数组并排放置:
+--------+--------+--------+--------+--------+--------+--------+-----+ |A[0].a |A[1].a |答[2].a |A[3].a |答[4].a |答[5].a |A[6].a |... | +--------+--------+--------+--------+--------+--------+--------+-----+ |B[0].a |B[0].b |B[1].a |B[1].b |B[2].a |B[2].b |B[3].a |... | +--------+--------+--------+--------+--------+--------+--------+-----+
使用上面的"叠加",很容易看出为什么您似乎要打印B
类中的b
成员。
虽然你不能依赖这种行为,但输出的可能解释,
考虑一组B
对象
a|b | a|b
object1 object2
当您将其解释为A*
a | b | a
object1 object2 object3
因此你会得到1 2 1 2..
.
相关文章:
- 如何循环打印顶点结构
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 如何在c++中打印目录
- 有一个打印语句的函数是一种糟糕的编程实践吗
- 在线编译器中的分段C++没有打印消息
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 如何将结构插入到集合中并打印集合的成员
- 在循环C++中指定字符串之后,不会打印该字符串
- 以螺旋方式打印矩阵的程序.(工作不好)
- 从控制台中删除最后打印的元素
- 如何使用Crypto++并为RSA返回可打印的字节/字符数组
- 如何仅使用对象名称打印特定于对象的成员
- 回溯C++不打印函数,因此文件
- 在一定长度后从数组中打印时缺少整数
- 为什么这个 c++ 代码打印出长度 5,当我打印出字符串时,程序会自动终止?
- 在gem5中打印文件中的所有cache_blocks
- 打印数字图案
- Log4cpp:以UTC/GMT时区打印日期
- 如何使用gdb制作一个可以漂亮地打印每个对象的C++函数