char p;
cout << &p;这不会打印字符p的地址。它会打印一些字符。为什么?
char p;
char *q;
q = &p;
cout << q;即使是这样也不会。为什么?
发布于 2015-03-22 06:15:24
我相信<<操作符会将其识别为字符串。将其转换为void*应该是可行的:
cout << (void*)&p;std::basic_ostream有一个专门的运算符,它接受一个std::basic_streambuf (基本上是一个字符串(在本例中)):
_Myt& operator<<(_Mysb *_Strbuf)与接受任何指针的运算符相反(当然,char*除外):
_Myt& operator<<(const void *_Val)发布于 2015-03-22 06:17:12
这是因为指向char的指针有自己的<<重载,它将指针解释为C字符串。
您可以通过向void*添加强制转换来修复代码,它是打印指针的重载:
char p;
cout << (void*)&p << endl;Demo 1.
请注意,问题发生在char指针上,而不是其他类型的指针。比方说,如果在声明中使用int而不是char,那么您的代码将在没有强制转换的情况下工作:
int p;
cout << &p << endl;Demo 2.
发布于 2015-03-22 06:16:29
std::cout会将char*视为字符串。你基本上看到的是内存中未初始化指针所在位置的内容--直到遇到一个终止空字符。如果您需要查看实际的指针值,将指针转换为void*应该会打印出来
https://stackoverflow.com/questions/29188668
复制相似问题