C++获取并输出char类型的地址

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类型数据的地址并输出,理论上应该直接输出两个地址,但是结果并不是这样。

要么输出乱码

image-20220328130431424

要么直接输出了字符变量的内容

image-20220328130807907

第一个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;
}

运行结果如下:

image-20220328133417180

发现cout << c1 << endl;cout << ptr3 << endl;的输出效果是一样的,因为c1是字符数组的首地址,因此输出c1和ptr3的效果是一样的。

但是当字符串数组只有一个字符的时候,其实和真正的单个字符是不一样的。

在初始化字符数组的时候,虽然hello只有5个字母,但是却占用了6个位置,因为在字符串末尾会自动添加一个\0表示字符串结束。

image-20220328134154179

#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;
}

image-20220328134320085

输出的结果也确实表示,大小是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;
}

image-20220328135454632

  • 8
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值