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

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]是等价的,可以理解为指向字符串数组的指针。

相关推荐
云知谷1 小时前
【软件测试】《集成测试全攻略:Mock/Stub 原理 + Postman/JUnit/TestNG 实战》
c语言·开发语言·c++·软件工程·团队开发
小龙报4 小时前
《算法通关指南C++编程篇 --- 初阶函数递归专题》
c语言·开发语言·c++·算法·创业创新·学习方法·visual studio
星轨初途4 小时前
《数据结构二叉树之堆 —— 优先队列与排序的高效实现(2)(下)》
c语言·开发语言·数据结构·经验分享·笔记·性能优化
Shylock_Mister4 小时前
ARM与x86交叉编译实战排错指南
linux·c语言·arm开发
高山有多高5 小时前
堆应用一键通关: 堆排序 +TOPk问题的实战解析
c语言·数据结构·c++·算法
程序猿追5 小时前
Ascend C编程范式总结:与CUDA的异同对比
c语言·开发语言·算法
晨非辰7 小时前
【数据结构初阶系列】归并排序全透视:从算法原理全分析到源码实战应用
运维·c语言·数据结构·c++·人工智能·python·深度学习
松涛和鸣12 小时前
11.C 语言学习:递归、宏定义、预处理、汉诺塔、Fibonacci 等
linux·c语言·开发语言·学习·算法·排序算法
鑫—萍17 小时前
C/C++精品算法——双指针(1)
c语言·c++·算法
智者知已应修善业19 小时前
【51单片机:两边向中间流水:即两边先点亮然后熄灭,次边的点亮再熄灭,直到最中间的两个点亮再熄灭,然后重复动作。】2023-3-4
c语言·c++·经验分享·笔记·嵌入式硬件·算法·51单片机