c++ - 数组与指针的问题

查看:109
本文介绍了c++ - 数组与指针的问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

#include <iostream>
using namespace std;
int main()
{
    int n;
    int arr[2][2] = {0};
    for (int i =0; i < 2; ++i)
    {
        for (int j = 0; j < 2; ++j)
        {
            arr[i][j] = i * j;
        }
    }
    for (int i = 0; i < 2; ++i)
    {
        for (int j = 0; j < 2; ++j)
        {
            cout << &arr[i][j] << '\t';
        }
        cout << endl;
    }
    cout << "=====================\n";
    cout << arr << endl;
    cout << arr + 1 << endl;
    cout << &arr[0] << endl;
    cout << &arr[0] + 1 << endl;
    cout << arr[0] << endl;
    cout << arr[0] + 1 << endl;
    cout << *(arr + 1) << endl;
    cout << *(&arr[0] + 1) << endl;
    return 0;
}


看了《c和指针》,关于指针和数组还是有困惑。在上面的代码里面,&arr[0] + 1不是地址吗?为什么我用*(&arr[0] + 1)还是打印的地址啊?为什么不是取地址啊?

int a = 2;
int* b = &a;

这两条语句,b是指针,打印出b和&b是不一样的,b占据有内存空间吧。如果&arr[0]是指针,但是我&(&a[0])为什么会报错,提示&a[0]不是左值,这里应该是&a[0]应该是右值,&a[0]只是代表一个地址?

既然arr + 1是地址了,为什么我用*取内容操作符,不是直接取内存里面的内容,而是变成arr[1],还是以地址的方式显示,从最上面的打印可以看出,arr + 1的地址是0x72fe38,我用*取这个地址的内容,为什么不是打印出内容给我呢?

解决方案

arr[0]是一个一维数组,
&arr[0]是指向一维数组的指针,
&arr[0]+1也是指向一维数组的指针,*(&arr[0]+1)是一维数组,数组在做右值的时候被自动转化指针,这是C语言中的解释

arr[0]是一个数组,&arr[0]是指向数组的指针,其实也可以理解为arr[0]的地址,只不过编译器知道它的类型,所以就叫它指针了。但是实际的内存中是没有一个地方存放&arr[0]或者说arr[0]的地址的。它不像变量b那样,b被声明了,编译器给它分配了内存空间,所以可以用取址&取到b的地址。

arr是数组,它的每个成员是一个数组int [2],每个成员的长度8个字节,arr + 1在做这个运算的时候被转换成了指向数组的指针int (*)[2],所以arr + 1的值就是数组arr的地址+8,它不光是一个地址,而且编译器知道它指向的数据的类型,这个在C语言的概念里就是指针了。所以*(arr+1)就是arr[1]了。

*(arr+1)就是表示的内存里的内容,但是呢这个内容又恰好是一个数组,数组被自动转换成了指向数组成员的指针,所以打印出来的是地址。如果是int arr1[2],那么*(arr1 + 1)就不一样了。

这篇关于c++ - 数组与指针的问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆