为便于说明,把问题略为简化:“定义的是指向字符的指针,为什么能输出整个字符串”?
在C++中,cout << p;中的p如果是字符型指针,就被解释为“从这个指针的值(地址)开始,一个字节接一个字节地把其内容按ASCII码对应的字符输出到终端,直到遇到'\0'停止,且不输出'\0'“。下面的代码表明,当把一个int变量的地址强制为char *型时,cout <<也会把4字节的int数据按字节的ASCII值输出字符串,以证明前述分析的正确性:
//#include "stdafx.h"//If the vc++6.0, with this line.
#include
using namespace std;
int main(void){
int a=6513249;
cout << (char *)&a << ' ' << &a << endl;
return 0;
}
输出是abc xxxxxxxx(这是a变量的16进制地址,不同平台值会不同)。
注:a的值是精心选择的,使它的前3个字节的ASCII码刚好是abc,后一个是0,否则输出可能是乱码,这里只是在说明cout <<输出字符指针时的机制。后面的&a表明当指针不是字符型时则输出指针的地址值,以与前一个字符型指针的处理机制相对照。
char* 类型的cout 形为就是显示其指向的字符串的。month[k] 的类型为 const char * ,显示其内容是正常的。
而*month[k] 的类型为const char,得到的是对应字符串的第一个字符,所以结果就是 J F什么的。
这个数组元素明显是char*啊。 指向字符的指针数组是char const (*month)[n_months]
当char *a="xxxxxxxx";
这个就是你数组中的一个元素吧?当使用cout<当使用cout<所以按照你的数组:你cout<<*month[k]<
C\C++中,当你给cout放一个字符指针的时候,它就一直输出,知道遇到\0这个结尾。而*month[K]是取值,它不是一个指针,所以输出单个值。
char *s
s代表一个内存地址
std::cout << s of type char *
会解释为字符串