运行如下代码
#includeusing 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有关。
#includeusing 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个位置,因为在字符串末尾会自动添加一个 表示字符串结束。
#includeusing 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个。
因为单个的字符末尾并没有 表示字符串的结束,而使用cout输出的时候,默认字符变量就是字符串,但是结尾没有 表示结束,所以就停不下来,把内存后边的内容也当做字符串来输出了,因此就会乱码,而输出结果为字符内容的可能是编译器识别到了这种情况,进行了纠正。总之,当地址是字符变量的时候,使用cout输出的结果不是想要的那一串地址编号。
解决 可以使用printfprintf不会自作多情以为字符类型的指针是一个字符串,只会老老实实输出地址;
使用cout输出地址的标准用法cout << (void *) ptr2 << endl; 为了避免出现类似的情况,使用cout输出所有类型地址的时候,都应该在前面加上类型转换,这样就可以输出地址了。
#includeusing 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("%prn",ptr2); cout << (void *) ptr2 << endl; return 0; }



