我今天试了一下,发现在C++中,如果我们想cout一个字符数组的话,那么它就会沿着这个地址,一直输出输出这个字符串,直到遇到'\0'。例如下面这个例子:
char *c="cadn\0hello";
cout<<c<<endl;
输出的结果是:cadn
如果我们自作聪明的想输出第一个字符的地址,例如这样输出:
cout<<&c[0]<<endl;
不幸的是,这样输出的结果依旧不是我们需要的地址。
但是,如果我们回归到C语言的话,例如用printf的话,如下:
printf("%x\n",&c[0]);
幸福的事情发生了,输出的结果是:
46f020
的确是字符串的首地址,但是,如果我们要输出字符串的地址,难道就这一种方法难道我们就不可以用我们C++上的cout达到我们的效果吗?
当然不是!
由于C++标准库中的I/O类对<<操作符重载,因此在遇到字符型指针的时候会将其作为字符串名进行处理,输出指针所指的字符串。既然如此,我们就别让它知道那是字符串指针,所以,需要用到强制类型转换,把字符串指针转换成无类型的指针。如下
cout<<(void *)c<<endl;
这样就可以达到我们需要的效果了!
只要别让编译器认为那是一个指向字符串的指针,那么就可以输出地址,而不是字符串的内容。所以,除了
cout<<(char *)c<<endl;
不可以之外,其他的都可以
cout << (int*)c << endl;
cout << (float*)c << endl;
cout << (double*)c << endl;
甚至
cout << (bool*)c << endl;
举例如下:
char *str="yangming";
cout<<str<<endl;
cout<<(char *)str<<endl;
cout<<(double *)str<<endl;
cout<<(float *)str<<endl;
cout<<(bool *)str<<endl;
printf("%p",str);
扩展阅读: http://topic.csdn.net/u/20120718/21/99505c0b-d575-49e4-8a5c-759139fd9bae.html