char *p = "Hello,World!";
cout << p << endl; //输出Hello,World!
cout << *p << endl; //输出H
正确输出:cout << (void *)p << endl;
************************************************************************************************************************************
一:原理分析及实现方法
上面的操作并不能达到我们想要的效果,
这主要是因为C++中对输出运算符进行了指定参数的重载;
对于第一种输出,对于传入的char型指针,运算符默认被重载输出‘\0’之前的所有字符:
ostream& operator << (ostream& output, char *c)
{
while (*c != '\0')
{
output << *c;
c = c + sizeof(char);
}
return output;
}
对于第二种则是直接输出一个char型数据;
理解了重载的原理,我们可以将传入的参数p的指针类型进行强制转换为void *(无类型指针):
输出运算符对于无类型指针的重载,结果可以直接输出该指针的地址,类似于C语言中的%p:
cout << (void *)p << endl;
那到底C++中的 "<<" 是如何针对无类型指针进行输出其地址,让我们参考官方的重载函数:
这里不知道被开发者封装了多少次(......),理解可以输出地址即可。
二:char *p = "xxxxx"与char p[] = "xxxxx"的差异
<1>首先我们来分析char *p = "xxxxx":
p与&p的地址不同!
这里的p即是首地址,&p则是p的地址(地址的地址),这里的&p也是一个无类型指针,只不过这个指针指向的空间有值,可以使用*(&p)来进行输出;
<2>然后我们分析char p[] = "xxxxx":
p与&p的地址一致!