数组的指针和引用的写法

指向数组的指针写法:
1。数组类型是包括维数信息的
2。int (*p1)[3]和int (*p2)[10]是两个不同的指针类型,一个可以指向int[3]类型的数组,一个可以指向int[10]类型的数组

int main()
{
    int arr[3];
    int (*ptr)[3] = &arr;
//    int **ptr2 = &arr; //err : cannot convert from 'int (*__w64 )[3]' to 'int **'

    char *strarr[2] = {"abc", "def"};
    char *(*pstr)[2] = &strarr;
//    char **pstr2 = &strarr; //err : cannot convert from 'char *(*__w64 )[2]' to 'char **'

    return 0;
}

数组引用写法:
int arr[3]的引用 int (&refArr)[3]同样带有维数的信息

void getRef(int (&arr)[3])
{
    for (int i = 0; i != 3; ++i)
    {
        arr[i] = i;
    }
}

void getPtr(int *arr, int n)
{
    for (int i = 0; i != n; ++i)
    {
        arr[i] = i;
    }
}

int main()
{
    int arr1[3];
    getRef(arr1);
    for (int i = 0; i != 3; ++i)
    {
        cout << arr1[i] << " ";
    }
    cout << endl;

    int arr2[6];
    getPtr(arr2, 6);
    for (int i = 0; i != 6; ++i)
    {
        cout << arr2[i] << " ";
    }
    cout << endl;

    return 0;
}

int a[2][3];
int b[8][3];

void funcn1(int (&ra)[2][3])
{}

void funcn2(int (*p)[][3])
{}

void funcn3(int (*p)[2][3])
{}

int main()
{
 funcn1(a);
 //funcn1(b); //error C2664: 'funcn1' : cannot convert parameter 1 from 'int [8][3]' to 'int (&)[2][3]'

 //funcn2(&a); //error C2664: 'funcn2' : cannot convert parameter 1 from 'int (*__w64 )[2][3]' to 'int (*)[][3]'
 //funcn2(&b); //error C2664: 'funcn2' : cannot convert parameter 1 from 'int (*__w64 )[8][3]' to 'int (*)[][3]'

 funcn3(&a);
 //funcn3(&b); //error C2664: 'funcn3' : cannot convert parameter 1 from 'int (*__w64 )[8][3]' to 'int (*)[2][3]'

 return 0;
}

### C语言中结构体指针数组与结构体数组指针的区别 #### 定义上的区别 在C语言中,**结构体指针数组**是一个指向多个不同结构体实例的指针集合,而**结构体数组指针**则是指向整个结构体数组的一个单一指针。 - **结构体指针数组**:这是一个普通的数组,其中每个元素都是一个指向特定类型的结构体的指针。 示例定义如下: ```c struct Test { char cdata; int idata; }; struct Test obj1 = {'A', 1}; struct Test obj2 = {'B', 2}; struct Test* ptrArray[2]; ptrArray[0] = &obj1; ptrArray[1] = &obj2; ``` - **结构体数组指针**:这是单个指针,它指向的是由连续存储的一系列相同类型结构体组成的数组的第一个元素。 示例定义如下: ```c struct Test arrayObj[2] = { {'X', 10}, {'Y', 20} }; struct Test (*ptrToArray)[2] = &arrayObj; ``` --- #### 访问方式的不同 对于这两种不同的数据形式,在访问其内部成员的方式上也存在差异: - 对于**结构体指针数组**,通过索引来获取对应的指针并间接访问目标对象的内容。 ```c printf("%c %d\n", (*ptrArray[0]).cdata, (*ptrArray[0]).idata); // 输出 A 1 printf("%c %d\n", ptrArray[0]->cdata, ptrArray[0]->idata); // 同样效果,更简洁写法 ``` - 而针对**结构体数组指针**来说,则需先解除对该数组整体地址的引用再进一步操作具体位置的数据项。 ```c printf("%c %d\n", (*(ptrToArray))[0].cdata, (*(ptrToArray))[0].idata); // 输出 X 10 printf("%c %d\n", (*ptrToArray)[1].cdata, (*ptrToArray)[1].idata); // 输出 Y 20 ``` 上述两种方法均实现了对相应字段值的有效读取[^1]。 --- #### 存储布局对比 从内存分配角度来看两者也有显著差别: - 当声明了一个`struct Test* ptrArray[N];`这样的结构体指针数组时,实际上只是预留了一片能够容纳N个指针大小的空间,并未自动初始化这些指针所指向的具体实体;因此还需要手动为其赋初值使其真正关联到有效的结构体实例上去才行。 - 反观像这样定义出来的结构体数组指针:`struct Test(*ptrToArray)[M]=&someStructArray;`,这里已经明确了这个变量实际代表的就是某个已存在的含有M个元素规模之下的结构体数组首址信息而已. --- #### 应用场景分析 基于以上特性描述可以得出它们各自适用场合的大致范围: - 如果程序设计需求涉及到频繁更换或者动态调整各个独立个体间相互关系的话那么采用「结构体指针数组」会更加灵活便捷一些因为只需要简单修改对应下标的指向即可完成重新配置工作无需顾虑底层物理排列顺序等问题. - 假设当前任务重点在于高效处理大批量同质化记录单元并且希望保持原有线性序列不变的情况下选用「结构体数组指针」往往能带来性能优势由于减少了额外层次跳跃动作从而加快存取速度同时简化逻辑控制流程便于维护管理. ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值