首页
学习
活动
专区
工具
TVP
发布

C语言指针引用二维数组

最近看谭浩强的《C程序设计》,第248页 例8.11 看到这里例子感觉有点懵,所以根据这个例子自己总结了下: 一.不用取地址符和指针 1.二维数组的元素: a[0][1] 2.二维数组的地址:...2.1 0行首地址:a 2.2 1行0列元素地址:a[1] 2.3 1行首地址 : a+1 二.用取地址符(当然只能表示数组的地址) 1.0行首地址:&a[0] 2.元素地址:&a[0][1]...三.用指针(用指针无法指向某行的首地址) 1.元素值:* ((a+0)+1) 2.元素地址:(a+2)+0 写一个测试程序: #include int main() { int...a[3][4] = {1,2,3,4,5,6,7,8,9,12,13,0}; printf("----------------------\n"); printf("不用指针和取地址符\n");...d,%d,%d,%d\n",a[0][1],a,a[1],a+1); printf("用取地址符\n"); printf("%d,%d\n",&a[0][1],&a[1]); printf("用指针

90330
您找到你想要的搜索结果了吗?
是的
没有找到

C语言进阶】指针数组 —— 数组指针

鸽芷咕:个人主页 个人专栏:《C语言进阶篇》《C语言初阶篇》 ⛺️生活的理想,就是为了理想的生活!...文章目录 前言 指针数组 指针数组的定义 ✅ 指针数组的使用 如何访问存放在的指针数组里的数组元素 数组指针 数组指针的定义 &数组名VS数组数组指针的使用 数组指针(实例) 全篇总结...数组指针or指针数组是有明显不一样的下面我们就来看看 本期文章收录在《C语言初阶篇》,大家有兴趣可以看看呐! ⛺️ 欢迎铁汁们 ✔️ 点赞 收藏 ⭐留言 !...=其实二维数组的本质就指针数组== 代码演示: #define _CRT_SECURE_NO_WARNINGS 1 #include void print_arr1(int arr...arr,表示首元素的地址 //但是二维数组的首元素是二维数组的第一行 //所以这里传递的arr,其实相当于第一行的地址,是一维数组的地址 //可以数组指针来接收 print_arr2(arr,

10810

C二维数组指针

C语言中的二维数组是按行排列的,也就是先存放 a[0] 行,再存放 a[1] 行,最后存放 a[2] 行;每行中的 4 个元素也是依次存放。...数组 a 为 int 类型,每个元素占用 4个字节,整个数组共占用 4×(3×4) = 48 个字节。 C语言允许把一个二维数组分解成多个一维数组来处理。...也就是说,p+1会使得指针指向二维数组的下一行,p-1会使得指针指向数组的上一行。 数组名 a 在表达式中也会被转换为和 p 等价的指针!...: 指针数组二维数组指针在定义时非常相似,只是括号的位置不同: int *(p1[5]); //指针数组,可以去掉括号直接写作 int *p1[5]; int (*p2)[5]; //二维数组指针...二维数组指针是一个指针,它指向一个二维数组,以上面的 p2 为例,它占用 4 个字节的内存。 看完本文有收获?请转发分享更多人 因为分享是一种美德

92820

C语言指针(二)数组指针指针数组

数组指针/指针数组 数组指针是: ❝指向数组指针,它本质上还是一个指针,类比普通指针指针数组是: ❝一个存放指针数组,本质上是数组,就如经常说的字符数组,整型数组一样 ❞ 2.1 数组的理解...arr[1] => *(&arr +1) 先让内存地址加下标,再通过指针获取到元素 ❞ 2.3 数组指针 数组指针就是指向数组第一个元素的指针,相信认真看了2.1和2.2的你能够很快理解 定义一个数组指针...int a[] = {1, 3, 5, 7}; // 一个数组 int (*p)[4] = &a; // 定义一个指针,指向数组的头元素 通过指针访问第二个数组元素: printf("访问数组的第二个元素...指针数组」,顾名思义,他是个数组,就如经常说的字符数组,整型数组一样,只不过指针数组的定义方法和存储对象也有亿点点不一样。...定义一个指针数组(以整型为例) int *pArr[10]; // 定义一个指针数组 「要注意与数组指针的定义区别开」 数组指针的定义: int (*arrP)[10]; 一定要注意这个括号,这涉及到了

1.3K00

C 语言数组 ( 数组指针 | 数组指针定义 | 直接定义 数组指针 )

文章目录 总结 一、直接定义 数组指针 二、完整代码示例 总结 int (*p)[3] = NULL; 一、直接定义 数组指针 ---- 直接定义 数组指针 , 首先 , 定义一个普通数组 ,...数组指针类型 变量 , 指针指向的数据类型为 int[3] 数组类型的变量 array2 ; ArrayPointer p = NULL; p = &array2; 验证上述 定义的数组指针...; } 使用 数组指针 , 打印数组元素内容 : // 使用 数组指针 访问数组中的值 for(i = 0; i < 3; i++) { printf("..., 数组元素是指针 (作为参考) char *array = {"12", "ab", "34"}; // 数组指针 , 使用指针变量指向数组 // 首先 , 定义一个普通数组..., 将 array2 变量地址赋值给该 数组指针类型 变量 // 指针指向的数据类型为 int[3] 数组类型的变量 array2 p = &array2; // 为数组赋值

3.3K20

C语言C语言数组指针

---- 友情提醒:本文可能是全csdn最详细的指针内容了,希望你能用心读下去 前言 接下来的讲解部分是指针的进阶,包含多种指针以及对应的数组,这部分章节对我们来说很重要,也是c语言中的重点模块儿,重要性不言而喻...(c/c++会把常量字符串储存到单独的一个内存区域中) 当这两个指针指向同一个常量字符串时,实际上就是指向同一块儿地址**(指针就是地址,地址就是指针)** 2.数组指针 2.1数组指针的定义 1.数组指针嘛...,当二维数组数组名被当作参数传递时,我们可以把二维数组想象成多个一维数组的集合,则每一个一维数组相当于这个二维数组的每一个元素,这样来看二维数组名其实就是第一行一维数组的地址,所以我们就可以用数组指针来接受这个参数...当我们拿到第一行所有的元素之后,想要拿第二行的数组的元素个数时,我们只要让这个接收二维数组数组名的指针,也就是p+1,不就好了么。...这个完全正确,用指针数组来接收二维数组的首行数组的地址 {} void test(int**arr) 二级指针接收是没必要,这里又不是传一级指针过来,人家就传个地址而已 {} int main() {

64.2K22

C 语言数组 ( 数组指针 | 数组指针定义 | 使用 数组指针类型 定义数组指针 )

文章目录 总结 一、使用 数组指针类型 定义数组指针 二、完整代码示例 总结 // 首先 , 定义 数组指针类型 别名 typedef int(*ArrayPointer)[3];...// 然后 , 声明一个 数组指针类型 变量 ArrayPointer p = NULL; 一、使用 数组指针类型 定义数组指针 ---- 使用 数组指针类型 定义数组指针 , 首先 , 使用...typedef 定义一个数组指针类型 , typedef int(*ArrayPointer)[3]; 然后 , 定义一个普通数组 , 之后的 数组指针 指向该数组 , int array2...[3] = {0}; 最后 , 声明一个 数组指针类型 变量 , 将 array2 变量地址赋值给该 数组指针类型 变量 , 指针指向的数据类型为 int[3] 数组类型的变量 array2 ;..., 数组元素是指针 (作为参考) char *array = {"12", "ab", "34"}; // 数组指针 , 使用指针变量指向数组 // 使用 数组指针类型 定义数组指针

2.9K10

C 语言数组 ( 数组指针 | 数组指针定义 | 使用 数组类型* 定义数组指针 )

* 定义数组指针 ---- 数组类型指针 就是 定义一个指针 , 指向数组首地址 ; 使用 数组类型* 定义数组指针 , 首先 , 定义数组类型 别名 , typedef int(ArrayType...)[3]; 然后 , 使用别名类型 , 声明数组变量 , ArrayType array2 = {0}; 最后 , 声明一个指针 , 将 array2 变量地址赋值给该指针 , 指针指向的数据类型为...---- 代码示例 : #include #include #include int main() { // 指针数组 , 数组元素是指针...char *array = {"12", "ab", "34"}; // 数组指针 , 使用指针变量指向数组 // 使用 数组别名 定义数组指针 // 首先 ,...// 最后 , 声明一个指针 , 将 array2 变量地址赋值给该指针 // 指针指向的数据类型为 int[3] 数组类型的变量 array2 ArrayType *p = NULL;

3.4K20

C语言数组指针

对于数组元素的使用,采用的是数组名加下标的方式。 比如有数组 int a[10]; 里面10个元素分别是 a[0]、a[1]、a[2]......a[9]。...引用数组元素,还有另外两种方式。 首先,我们要知道数组名a代表的含义,它表示的是首地址,数组第一个元素a[0]的地址。...数组在内存空间位置是固定的,地址不变,这也就是为什么不能给数组名a赋值或者改变它的值。 那么a+1是什么意思呢?很多人误以为,那就是首地址加一呗。a+1表示的是数组里面第二个元素的地址。...a+i 等价于 &a[i] *(a+i) 等价于 a[i] 第二种方式就是直接使用指针来引用数组元素。...定义指针 int *p; 使用p=a;或者p=&a[0]让指针指向数组第一个元素a[0],那么通过指针p的移动,如p++等也可以遍历数组所有元素。

1.6K10

C语言 | 指针引用数组

C语言数组元素的指针 指针变量既可以指向变量,也可以指向数组元素,所谓数组元素的指针就是数组元素的地址。 引用数组元素可以用下标法,也可以用指针法,即通过指向数组元素的指针找到所需的元素。...在C语言中,数组名代表数组中首元素的地址,使用指针法能使目标程序质量高,因为其占内存少,运行速度快。 C语言在引用数组元素时指针的运算 在一定条件下允许对指针进行加和减的运算。...C语言数组名作函数参数 C语言调用函数时虚实结合的方法都是采用“值传递”方式,当用变量名作为函数参数时传递的是变量的值,当用数组名作为函数参数时。...C语言通过指针引用多维数组 1、多维数组元素的地址 性质与二维数组差不多,但需要注意的是,多维数组由于分配内存情况不同,所显示的地址可能是不同的。...100道C语言源码案例请去公众号:C语言入门到精通

1.8K20

C 语言】二级指针作为输入 ( 二维数组 | 二维数组遍历 | 二维数组排序 )

文章目录 一、二维数组 1、二维数组声明及初始化 2、二维数组遍历 3、二维数组排序 二、完整代码示例 一、二维数组 ---- 前几篇博客中 , 介绍的是指针数组 ; 指针数组 的 结构特征 是 ,...数组中的每个元素 , 即每个指针变量 可以 指向不同大小的 内存块 ; 二维数组指针数组 的结构不同 , 二维数组 的 内存结构 是整齐的连续的 内存块 , 每个 一维指针 指向的内存块 的大小都是相同的...; // 使用指针访问 //printf("%s\n", *(array + i)); } 3、二维数组排序 二维数组排序 : 对二维数组进行排序 , 不能单纯的交换指针指向...二维数组排序 // 对 指针数组 进行排序 , 排序依据是 指针 指向的数据对比 for(i = 0; i < num; i++) { for(j = i +...二维数组排序 // 对 指针数组 进行排序 , 排序依据是 指针 指向的数据对比 for(i = 0; i < num; i++) { for(j = i +

1.5K10

C语言 | 指针数组与多重指针

C语言什么是指针数组C语言中一个数组,若其元素均为指针类型数据,称为指针数组,也就是说,指针数组中的每一个元素都存放一个地址,相当于一个指针变量。...C语言指向指针数据的指针 //定义一个指向指针数据的指针变量: char **point; point的前面有两个*号。...C语言指针数组作main函数的参数 main函数的第一行一般写成 int main() 或 int main(void) 括号中是空的或void,表示main函数没有参数,调用main函数时不必给出实参...命令行的一般形式 命令名 参数1 参数2……参数n C语言指向指针指针 #include int main() {     int number =100;     int *p1...100道C语言源码案例请去公众号:C语言入门到精通

1.7K20

C语言数组——二维数组

前面介绍了一维数组,接下来介绍如何定义和使用二维数组。...通常在处理二维数组的时候,为了便于理解,都将数组视为一个矩阵,常量表达式1表示矩阵的行数,而常量表达式2表示矩阵的列数。与一维数组一样,在定义二维数组时,常量表达式同样不能为变量。...数组中各个元素在矩阵中对应的位置由二维数组的两个下标决定。...知道了二维数组的这种特殊结构之后,接下来通过下图来了解二维数组在内存中的存储结构。...通过上述二维数组在内存中的存储结构图可以发现,二维数组中的所有元素都存储在一片连续的内存单元中,所占用的内存大小为元素类型所占用的内存大小乘以第一维及第二维的长度。

8K10

其他|二维指针数组指针指针数组

当我们拿tensorflow框架跑一遍,发现时间效率不能满足我们的要求时,往往核心逻辑就会考虑用c++定制改写。 c++的精华无疑是指针指针的灵活,创建和销毁完全靠我们掌控。...用到指针,一般都会用到二维指针数组指针,下面总结下它们的某些应用场景。...2二维指针 二维指针指针变量指向的是指针,如: char **pa; 常用二维指针的场合是第一维和第二维元素个数都不确定的情况下,或者个数是动态变化的场合。 二维指针如何申请堆地址?...这样就申请了一个m行n列的二维动态数组。...和二维指针相比,它有一个维度的个数必须是确定的,此处等于2,它创建如下: pa = new char[m][2]; 释放: delete [] pa; 4指针数组 指针数组数组,里面的元素是指针

1.2K51

C语言指针进阶:字符指针&&数组指针&&函数指针

✨作者:@平凡的人1 ✨专栏:《C语言从0到1》 ✨一句话:凡是过往,皆为序章 ✨说明: 过去无可挽回, 未来可以改变 ---- 感谢您的点赞与关注,同时欢迎各位有空来访我的平凡舍 --...-- 文章目录 @[toc] 前言 字符指针 指针数组 数组指针 &数组名 与 数组数组指针的使用 数组传参、指针参数 一维数组传参 二维数组传参 一级指针传参 二级指针传参 函数指针 结语 前言...C/C++会把常量字符串存储到单独的一个内存区域,当指针指向同一个字符串的时候,他们实际会指向同一块内存。但是用相同的常量字符串去初始化不同的数组的时候就会开辟出不同的内存块。...arr,表示首元素的地址 //但是二维数组的首元素是二维数组的第一行 //所以这里传递的arr,其实相当于第一行的地址,是一维数组的地址 //可以数组指针来接收 print_arr2(arr,...{ //二维数组数组名,表示首元素的地址,第一行是一个一维数组 //一维数组的地址不能放到二级指针上。

2.8K20

详解C语言中的数组指针指针数组

·详解数组指针指针数组 ·数组指针 一、区分 首先我们需要了解什么是数组指针以及什么是指针数组,如下图: int *p[5]; int (*p)[5]; 数组指针的意思即为通过指针引用数组,p先和*结合...三、通过指针引用多维数组 1.多维数组元素的地址 我们以二维数组为例,首先需要明确一点的是二维数组的首元素地址并非一个单个元素,而是首行的地址,如下图: 下面我们列出相关地址的表示方式: 表示形式 含义...a 二维数组名,指向a[0] a[0], *(a+0), *a 0行0列元素地址 a+1, &a[1] 1行首地址 a[1], *(a+1) a[1][0]的地址 a[1]+2, *(a+1)+2,...&a[1][2] a[1][2]的地址 *(a[1]+2), *(*(a+1)+2), a[1][2] a[1][2]的值 上图都是二维数组中地址的不同表示形式。...因此我们可以得出指针数组的定义。指针数组:一个数组的元素均为指针类型数据,称为指针数组

2.1K20
领券