指针数组与数组指针的理解

cpp 复制代码
typedef struct vexnode
{
    int key;
    struct arcnode *next;
}vexnode, adjlist[MVNUM];
void init(adjlist *list);
void init(adjlist *list) {
    for(size_t i = 0; i < MVNUM; i++)
    {
        list[i].key = i;
        list[i].next = NULL;
    }
}

上述代码编译的时候没有报错,但是运行的时候,出现错误,list的内存信息指向了一些未知地方。

这里init函数中的形参是指向结构体数组的指针,以上访问list[i]是不正确的。虽然list数组已经分配了地址,但是*list是一个指针,list+1指向了一个未知的位置,而不是list[1].

指针在C语言中有着举足轻重的地位。指针的本体是一个整形地址,地址在汇编中是很常见的概念,硬件语言中,地址信息一般以数字的形式存放与代码中,只是C语言为了隐藏硬件中的细节,从而定义了指针的概念。

指针数组与数组指针

cpp 复制代码
    char *a[] = {"gde","abc","cdd","acef","bdghs"};//

    char **p = a;

从上述代码看:

a是一个数组,这个数组存放了若干字符串,而a[i]就是这些字符串的首地址。

所以a是一个指针数组。

cpp 复制代码
void print(char **p, int n) {

    for(int i = 0; i < n; i++) {

        printf("The %dth string is:%s\n", i+1, *p++);

    }

}

二维指针*p指向的是a[0], (*p+1)指向的是a[1].

指针p是指向二维数组的一个指针,即数组指针。可以通过二维指针来访问二维数组。

**p与(*p)[5]是等价的,可以理解为指向字符串数组的指针。

相关推荐
John.Lewis20 分钟前
数据结构初阶(19)外排序·文件归并排序的实现
c语言·数据结构·排序算法
John.Lewis25 分钟前
数据结构初阶(16)排序算法——归并排序
c语言·数据结构·排序算法
wearegogog1231 小时前
C语言中的输入输出函数:构建程序交互的基石
c语言·开发语言·交互
艾莉丝努力练剑13 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
Cx330❀15 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
..过云雨16 小时前
01.【数据结构-C语言】数据结构概念&算法效率(时间复杂度和空间复杂度)
c语言·数据结构·笔记·学习
谱写秋天17 小时前
在STM32F103上进行FreeRTOS移植和配置(STM32CubeIDE)
c语言·stm32·单片机·freertos
我不是板神17 小时前
程序设计|C语言教学——C语言基础2:计算与控制语句
c语言
基于python的毕设18 小时前
C语言栈的实现
linux·c语言·ubuntu
promising-w1 天前
【嵌入式C语言】六
c语言·开发语言