在剛開始學習C/C++過程中,我們希望輸出各個變量的地址來窺探一些我們“百思不得其解”的現象,例如搞清函數堆棧相關的程序內部秘密。
先看下面示例:
#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的輸出地址:
將源碼中
cout << "m_ch1地址:" << &(test.m_ch1) << endl;
改為:
printf("m_ch1地址:%p\n",&(test.m_ch1));
m_char1的輸出地址:
為什么會出現這樣現象,因為字符串是以空終止符('\0')結尾的字符數組,通過字符串中第一個字符的指針訪問字符串。字符串的值是字符串中第一個字符的(常量)地址。&m_char1是一個char*變量,但&m_char1保存的字符串是沒有終止符('\0'),因此輸出亂碼。
無論要輸出哪一種變量地址,強制類型轉換可以解決大多數問題,如上將char*轉換為void*輸出。