在刚开始学习C/C++过程中,我们希望输出各个变量的地址来窥探一些我们“百思不得其解”的现象,例如搞清函数堆栈相关的程序内部秘密。
先看下面示例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
#include< stdio.h > #include< iostream > using namespace std; class TestArrange { public: long m_lng; char m_ch1; TestArrange() { m_lng = 0; m_ch1 = 'a'; m_int = 0; m_ch2 = 'a'; } const int* GetIntAddr() { return &m_int; } const char* GetChar2Addr() { return &m_ch2; } private: int m_int; char m_ch2; }; int main(void) { TestArrange test; cout << "对象的地址:" << &test << endl; cout << "m_lng地址:" << &(test.m_lng) << endl; cout << "m_ch1地址:" << &(test.m_ch1) << endl; cout << "m_int地址:" << test.GetIntAddr() << endl; cout << "m_ch2地址:" << (void *)test.GetChar2Addr() << endl; return 0; } |
重点来看m_char1的输出地址:
将源码中
1
|
cout << "m_ch1地址:" << &(test.m_ch1) << endl; |
改为:
1
|
printf("m_ch1地址:%p\n",&(test.m_ch1)); |
m_char1的输出地址:
为什么会出现这样现象,因为字符串是以空终止符('\0')结尾的字符数组,通过字符串中第一个字符的指针访问字符串。字符串的值是字符串中第一个字符的(常量)地址。&m_char1是一个char*变量,但&m_char1保存的字符串是没有终止符('\0'),因此输出乱码。
无论要输出哪一种变量地址,强制类型转换可以解决大多数问题,如上将char*转换为void*输出。
以上这篇浅谈C++中char型变量的地址输出就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/yizhengdaodu/archive/2017/09/26/7598949.html