小编给大家分享一下C++中char型变量地址输出的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
在刚开始学习C/C++过程中,我们希望输出各个变量的地址来窥探一些我们“百思不得其解”的现象,例如搞清函数堆栈相关的程序内部秘密。
先看下面示例:
#include<stdio.h> #include<iostream> using namespace std; class TestArrange { public: long m_lng; char m_ch2; TestArrange() { m_lng = 0; m_ch2 = 'a'; m_int = 0; m_ch3 = 'a'; } const int* GetIntAddr() { return &m_int; } const char* GetChar2Addr() { return &m_ch3; } private: int m_int; char m_ch3; }; int main(void) { TestArrange test; cout << "对象的地址:" << &test << endl; cout << "m_lng地址:" << &(test.m_lng) << endl; cout << "m_ch2地址:" << &(test.m_ch2) << endl; cout << "m_int地址:" << test.GetIntAddr() << endl; cout << "m_ch3地址:" << (void *)test.GetChar2Addr() << endl; return 0; }
重点来看m_char1的输出地址:
将源码中
cout << "m_ch2地址:" << &(test.m_ch2) << endl;
改为:
printf("m_ch2地址:%p\n",&(test.m_ch2));
m_char1的输出地址:
为什么会出现这样现象,因为字符串是以空终止符('\0')结尾的字符数组,通过字符串中第一个字符的指针访问字符串。字符串的值是字符串中第一个字符的(常量)地址。&m_char1是一个char*变量,但&m_char1保存的字符串是没有终止符('\0'),因此输出乱码。
无论要输出哪一种变量地址,强制类型转换可以解决大多数问题,如上将char*转换为void*输出。
以上是“C++中char型变量地址输出的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。