C++中指针数组问题 定义的是指向字符的指针数组 为什么输出的又是整个字符串

char const* month[n_months]={"January","February","March","April","May","June","July","August","September","October","November","December"};

int main()
{
for(int k=0;k!=n_months;++k)
std::cout<<month[k]<<":\t"<<std::endl;//输出是January: 等,整个自字符串
如果将*month[k]就只有首字母J:
return 0;
}

为便于说明,把问题略为简化:“定义的是指向字符的指针,为什么能输出整个字符串”?

在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 <iostream>
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<<a<<endl;时,输出的就是整个字符串。
当使用cout<<a[0]<<endl;或者cout<<*a<<endl;时,输出的级是字符串中第一个字母。
所以按照你的扮启数组:你cout<<*month[k]<<endl;才是第一个字母J

C\C++中,当你给cout放一个字符指针的时候,它就一直输出,知道厅孝如遇到\0这个结尾。而*month[K]是取值,它不是一个指针,慎正所以输出单个值。
char *s
s代表一个内唯卖存地址

std::cout <<樱老 s of type char *
会解指颂逗释为字符串