为什么不显示 Char 数据的地址?
考虑此代码:
class Address { public: int i; char b; string c; void showMap(); }; void Address::showMap() { cout << "address of int : " << &i << endl; cout << "address of char : " << &b << endl; cout << "address of string : " << &c << endl; }
运行此代码时,您可能会注意到 char 变量 'b' 的地址未显示在输出中。相反,您会看到一个空白区域。为什么会发生这种情况?
原因在于地址运算符 (&) 如何处理不同的数据类型。当应用于 char 变量 &b 时,您将获得一个 char 指针,即 char *。
默认情况下,输出运算符
要解决此问题,您可以使用以下方法:
cout << "address of char : " << (void *) &b << endl;
这里,我们将 b 的地址转换为 void *,然后再将其与输出运算符一起使用。这可确保运算符将其视为指向内存位置的指针,而不是字符序列。
为什么地址之间的差异为 8?
如果您将如果将成员变量“int”、“char”和“string”设为 public,您可能会观察到另一个有趣的行为。 'int' 和 'string' 的地址差始终为 8。这是因为:
当编译器为类成员分配内存时,它会以将它们与各自的边界对齐的方式进行分配。在本例中,char 变量“b”占用一个字节,留下 3 个字节的未使用空间。该空格后面是字符串变量 'c',它与最近的 4 字节边界对齐。
因此,'&c' 和 '&b' 的地址之间的差将为 1 (对于 'b') 3 (对于未使用的空间) 4 (对于 'c' 的 4 字节对齐) = 8.
以上是为什么在 C 中 Char 变量的地址显示不正确?的详细内容。更多信息请关注PHP中文网其他相关文章!