C++获取并输出char类型的地址
现象
运行如下代码
#include <iostream>
using namespace std;
int main()
{
int a = 10;
char c = 'c';
int* ptr1 = 0;
char* ptr2 = 0;
ptr1 = &a;
ptr2 = &c;
cout << ptr1 << endl;
cout << ptr2 << endl;
return 0;
}
分别取一个int和char类型数据的地址并输出,理论上应该直接输出两个地址,但是结果并不是这样。
要么输出乱码
要么直接输出了字符变量的内容
第一个int的地址可以正常输出,但是char的地址并没有输出。
分析
这个现象应该和cout 有关。
#include <iostream>
using namespace std;
int main ()
{
int a = 10;
char c = 'c';
char c1[] = "hello";
int *ptr1 = 0;
char *ptr2 = 0;
char *ptr3 = 0;
ptr1 = &a;
ptr2 = &c;
ptr3 = c1;
cout << ptr1 << endl;
cout << ptr2 << endl;
cout << c1 << endl;
cout << ptr3 << endl;
return 0;
}
运行结果如下:
发现cout << c1 << endl; 和cout << ptr3 << endl; 的输出效果是一样的,因为c1是字符数组的首地址,因此输出c1和ptr3的效果是一样的。
但是当字符串数组只有一个字符的时候,其实和真正的单个字符是不一样的。
在初始化字符数组的时候,虽然hello只有5个字母,但是却占用了6个位置,因为在字符串末尾会自动添加一个\0表示字符串结束。
#include <iostream>
using namespace std;
int main ()
{
int a = 10;
char c = 'c';
char c1[] = "hello";
int *ptr1 = 0;
char *ptr2 = 0;
char *ptr3 = 0;
ptr1 = &a;
ptr2 = &c;
ptr3 = c1;
cout << ptr1 << endl;
cout << ptr2 << endl;
cout << c1 << endl;
cout << ptr3 << endl;
cout << sizeof (c1) << endl;
return 0;
}
输出的结果也确实表示,大小是6个。
因为单个的字符末尾并没有\0表示字符串的结束,而使用cout输出的时候,默认字符变量就是字符串,但是结尾没有\0表示结束,所以就停不下来,把内存后边的内容也当做字符串来输出了,因此就会乱码,而输出结果为字符内容的可能是编译器识别到了这种情况,进行了纠正。总之,当地址是字符变量的时候,使用cout输出的结果不是想要的那一串地址编号。
解决
可以使用printf
printf不会自作多情以为字符类型的指针是一个字符串,只会老老实实输出地址;
使用cout输出地址的标准用法
cout << (void *) ptr2 << endl; 为了避免出现类似的情况,使用cout输出所有类型地址的时候,都应该在前面加上类型转换,这样就可以输出地址了。
#include <iostream>
using namespace std;
int main ()
{
int a = 10;
char c = 'c';
char c1[] = "hello";
int *ptr1 = 0;
char *ptr2 = 0;
char *ptr3 = 0;
ptr1 = &a;
ptr2 = &c;
ptr3 = c1;
cout << ptr1 << endl;
cout << ptr2 << endl;
cout << c1 << endl;
cout << ptr3 << endl;
cout << sizeof (c1) << endl;
printf("%p\r\n",ptr2);
cout << (void *) ptr2 << endl;
return 0;
}
|