首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

二级指针、一维数组指针二维数组指针

二级指针 指针可以指向一个普通类型的数据,例如 int、double、char 等,也可以指向一个指针类型的数据,例如 int *、double *、char * 等。...如果一个指针指向的是另外一个指针,我们就称它为二级指针,或者指向指针指针。...C语言不限制指针的级数,每增加一级指针,在定义指针变量时就得增加一个星号*。page 是一级指针,指向普通类型的数据,定义时有一个*;ppage 是二级指针,指向一级指针 page,定义时有两个*。...实际开发中会经常使用一级指针二级指针,几乎用不到高级指针。...,类型就是数组元素的地址类型(通过sizeof也可以看出来) 二维数组指针 二维数组可以理解为每一个元素都是一个一维数组数组,这样就可以很好的理解二维数组指针了。

84520

指针详解(二级指针指针数组数组指针、字符指针二维数组传参、函数指针变量)(二)

一、二级指针 问:指针变量也是变量,是变量就有地址,那指针变量的地址存放在哪里?...二维数组可以被看作是数组数组,而指针数组数组指针。在该段代码中定义了三个一维数组,然后创建了一个指针数组,该数组指向这三个一维数组的开始地址。...然后你通过两个嵌套循环遍历这个“二维数组并打印其内容。 此模拟二维数组与真正二维数组的区别: 1、内存布局:真正的二维数组在内存中是连续的,而使用指针数组模拟的二维数组不是。...*)[5],那就意味着二维数组传参本质上也是传递了地址,传递的第一行这个一位数组的地址,那么形参可以写成数组指针的形式 五、函数指针变量 函数指针变量的创建 函数指针用来存放函数的地址 1、回调函数...如果我们要将函数的地址存放起来,就得创建函数指针变量咯,函数指针变量的写法其实和数组指针非常类似。

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

    【C 语言】二级指针 内存模型图 ( 指针数组 | 二维数组 | 自定义二级指针内存 )

    文章目录 前言 一、指针数组 二、二维数组 三、自定义二维指针内存 前言 绘制如下 3 种二级指针的内存模型 : // I....指针数组 char *p1 []= {"12", "ab", "34"}; // II. 二维数组 char p2[3][4] = {"12", "ab", "34"}; // III....指针数组 char *p1[] = {"12", "ab", "34"}; 指针数组 内存结构图 : 在 栈内存 中 , 是一个 指针数组 , 数组中有 3 个元素 , 都是指针数据类型 ; 指针...指向的 位置 是 全局区 的 常量区 ; 二、二维数组 ---- 绘制 二维数组 的内存模型图 : // II....二维数组 char p2[3][4] = {"12", "ab", "34"}; 绘制结果如下 : 上述 二维数组 都在 栈内存中 , 每个 一维数组 都占 4 字节 ; 一维数组中 , 默认值都为

    83410

    c-指针数组二级指针数组指针

    二级指针中,第一个指针含第二个指针的地址,第二个指针再指向含预期值的变量。 间接寻址的级数不受限制,但极少需要二级以上的间址。实际上,过深的间址难以理解,容易引起概念错误。...为了通过二级指针间接访问到目标值,必须使用双星号。如上所示。 ?...,即二级指针 //给指针数组p赋值,让指针数组的每个元素都指向数组a中元素的内存地址 for(i=0;i<5;i++) p[i]=&a[i];...("\n"); p++; //让指针指向二维数组的第2行 for(i=0;i<5;i++) printf("%d",(*p...(2)p=a,使得p指向二维数组a的第一行。而后通过(*p)[i]访问该行的每一个元素。 (3)p++,使p指向二维数组a的第二行。 注意:区别int (*p)[5]和int *p[5]。

    85430

    【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++的精华无疑是指针指针的灵活,创建和销毁完全靠我们掌控。用到指针,一般都会用到二维指针数组指针,下面总结下它们的某些应用场景。...2二维指针 二维指针指针变量指向的是指针,如: char **pa; 常用二维指针的场合是第一维和第二维元素个数都不确定的情况下,或者个数是动态变化的场合。 二维指针如何申请堆地址?...这样就申请了一个m行n列的二维动态数组。...与申请顺序相反: for(int i=0; i<m; i++){ delete[] pa[i]; } 最后释放pa: delete[] pa; 3数组指针 数组指针,是指向数组指针,如:...和二维指针相比,它有一个维度的个数必须是确定的,此处等于2,它创建如下: pa = new char[m][2]; 释放: delete [] pa; 4指针数组 指针数组数组,里面的元素是指针

    1.2K51

    【C语言】指针&&二级指针&&数组指针&&指针数组详解

    指针理解的2个要点: 指针是内存中一个最小单元的编号,也就是地址 平时口语中说的指针,通常指的是指针变量,是用来存放内存地址的变量 int* p;//创建一个指针,指的就是指针变量 总结:指针就是地址...,但是不允许与指向第一个元素之前的那个内存位置的指针进行比较 可以从前往后遍历,但是不要从后往前遍历 1.6 二级指针 指针变量也是变量,是变量就有地址 二级指针变量存放一级指针变量的地址 同理,也有三级指针变量...,存放二级指针变量的地址 a的地址存放在p中,p的地址存放在pp中 p是一级指针,pp是二级指针 *pp通过对pp中的地址进行解引用,这样找到的是p,*pp访问的其实就是p **pp先通过*pp找到p,...int arr[6]; 指针数组 - 存放指针(地址)的数组 使用指针数组模拟一个二维数组 但是这跟二维数组不一样,之前我们讲到,二维数组内存是连续的,指针数组是模拟的二维数组 他的原理是...因为对一个二维数组,可以不知道有多少行,但是必须知道一行多少元素。

    56710

    二维数组指针_二维数组指针

    二维数组指针⑴ 用指针表示二维数组元素。 要用指针处理二维数组,首先要解决从存储的角度对二维数组的认识问题。...而每个大数组元素对应二维数组的一行,我们就称之为行数组元素,显然每个行数组元素都是一个一维数组 下面我们讨论指针二维数组元素的对应关系,清楚了二者之间的关系,就能用指针处理二维数组了。...指针变量的值可以改变,即它可以随时指向不同的数组或同类型变量,而数组名自它定义时起就确定下来,不能通过赋值的方式使该数组名指向另外一个数组。 例4 求二维数组元素的最大值。...C语言可以通过定义行数组指针的方法,使得一个指针变量与二维数组名具有相同的性质。...行数组指针的定义方法如下: 数据类型 (*指针变量名)[二维数组列数]; 例如,对上述a数组,行数组指针定义如下: int (*p)[4]; 它表示,数组*p有4个int型元素,分别为(*p)[0]、(

    1.4K20

    一级指针二级指针指针数组指针数组总结

    #一级指针二级指针指针数组指针数组总结 ##数组:C 语言中所有的数组都可以看成是一维数组数组传参的时候会发生降维问题,任何数组传参都会降维成指针。...##指针指针存放变量的地址,指向的值是变量的内容。 指针(一级指针二级指针、多级指针): 一级指针用普通变量的地址去接,二级指针用一级指针的地址去接,N级指针用N-1级指针的地址去接。...将二维数组赋给一指针: int a[3][4]; int (*p)[4]; //该语句是定义一个数组指针,指向含4个元素的一维数组。...p=a; //将该二维数组的首地址赋给p,也就是a[0]或&a[0][0] p++; //该语句执行过后,也就是p=p+1;p跨过行a[0][]指向了行a[1][] 所以数组指针也称指向一维数组指针...如要将二维数组赋给一指针数组: int *p[3]; int a[3][4]; p++; //该语句表示p数组指向下一个数组元素。

    1.7K20

    二级指针指针数组关系

    指针数组我们一般用来存放一组字符串,来进行比较或储存的作用,而操作指针数组可以通过两种方式,一种则是直接使用下标方式,而另外一种,则可以通过二级指针。..., char *argv[]) { char* pArray[] = { “apple”, “nokia”, “google”, “samsung”, “huawei”, NULL }; // 通常把指针数组的最后一个元素设置为...NULL // 这样就可以通过while循环直接遍历指针数组 // 而不需要知道指针数组内部元素的长度 char** p = pArray; // 指针数组可以直接赋值给二级指针 // pArray是指向一个指针数组首元素的...char*类型的指针 // 对一个 char*类型的指针再引用就是char**类型 // 通过二级指针遍历指针数组中的内容 int i = 0; while (*p) { // 两种方法一致 printf

    11910

    【C 语言】二级指针作为输入 ( 二维数组 | 二维数组内存大小计算 | 指针跳转步长问题 )

    文章目录 一、二维数组内存大小计算 二、二维数组内存大小意义 一、二维数组内存大小计算 ---- 给定一个二维数组 : 该 二维数组 中有 4 个 一维数组 , 每个一维数组有 10 个 char...二维数组 char array[4][10] = {"abc", "123", "258", "sfd"}; 计算二维数组大小 : 40 字节 ; // 求二维数组总的内存大小...int num = 4; // 排序时 , 交换指针变量时的临时变量 , 存储指针指向的内存所存储的数据 char tmp[10]; // I....---- 编译器操作 二维数组 时 , 只关心 二维数组 的整体内存结构 , 下面的二维数组 有 4 行 10 列 ; // I...., 不能是 二维指针 ; /* * 此处遍历时 , 注意指针的步长 , * 传入一个二级指针 char ** , 会出错 * 如果传入 二级指针 , * array[i] 等同于 *(array

    1.4K10

    【C 语言】二级指针作为输入 ( 二维数组 | 抽象业务函数 | 二维数组打印函数 | 二维数组排序函数 )

    文章目录 一、抽象 二维数组 业务函数 1、二维数组 打印函数 2、二维数组 排序函数 二、完整代码示例 一、抽象 二维数组 业务函数 ---- 1、二维数组 打印函数 注意 , 二维数组 作为 函数参数...输入到函数中 , 不能传入 二维指针 ; 此处遍历时 , 注意指针的步长 ,传入一个二级指针 char ** , 会出错 , 如果传入 二级指针 , array[i] 等同于 *(array + i)...array + i)); } return 0; } 2、二维数组 排序函数 二维数组排序时 , 也不能传入二维指针作为形参 , 需要传入 char array[4][10] 作为形参..., * 传入一个二级指针 char ** , 会出错 * 如果传入 二级指针 , * array[i] 等同于 *(array + i) * array 的步长是 10 */ int print_str...二维数组排序 // 对 指针数组 进行排序 , 排序依据是 指针 指向的数据对比 sort_array(array, num); // IV.

    93330

    指针二维数组

    先前已经写过二维数组的文章了,现在直接开始指针二维数组 int B[2][3]这个二维数组可以拆分成 创建了两个一维数组 B[0] B[1] 如果我这么写 int* p = B; 你肯定知道这是不行的...,因为我们讨论的是二维数组 这是一维数组的写法 是因为B相当于指向一维数组指针(这个一维数组有三个元素) int* p; &p = B; 经过两次解引用就可以得到二维数组的的首个元素 我们还需要再画一张图分析一下内存...说了那么多,就是要理解上图中的的伪代码 如果你已经理解了 那么你对二维数组指针已经理解的差不多了 说了那么多 正式进入二维数组指针应用 创建一个二维数组指针 and 遍历 int (*p)[3];可以这么理解这个指针指向了存放了三个整型数组的内存地址...]的值为 %d ", i, *(*(B + i) + j)); } printf("\n"); } } 运行截图 指针和多维数组 三维数组指针创建 int...(*p)[2][2]; 还是先画一个三维数组的内存图 跟二维数组指针是基本一样的 区别在于二维数组数组名解引用后是指向一维数组指针 三维数组数组名解引用后是指向二维数组指针 基于图片中的一些指针运算和解引用

    16610

    C二维数组指针

    为了更好的理解指针二维数组的关系,我们先来定义一个指向 a 的指针变量 p: int (*p)[4] = a; 括号中的*表明 p 是一个指针,它指向一个数组数组的类型为int [4],这正是 a...也就是说,p+1会使得指针指向二维数组的下一行,p-1会使得指针指向数组的上一行。 数组名 a 在表达式中也会被转换为和 p 等价的指针!...: 指针数组二维数组指针在定义时非常相似,只是括号的位置不同: int *(p1[5]); //指针数组,可以去掉括号直接写作 int *p1[5]; int (*p2)[5]; //二维数组指针...,不能去掉括号 指针数组二维数组指针有着本质上的区别:指针数组是一个数组,只是每个元素保存的都是指针,以上面的 p1 为例,在32位环境下它占用 4×5 = 20 个字节的内存。...二维数组指针是一个指针,它指向一个二维数组,以上面的 p2 为例,它占用 4 个字节的内存。 看完本文有收获?请转发分享更多人 因为分享是一种美德

    99920

    OpenCV二维Mat数组二级指针)在CUDA中的使用

    在写CUDA核函数的时候形参往往会有很多个,动辄达到10-20个,如果能够在CPU中提前把数据组织好,比如使用二维数组,这样能够省去很多参数,在核函数中可以使用二维数组那样去取数据简化代码结构。...当然使用二维数据会增加GPU内存的访问次数,不可避免会影响效率,这个不是今天讨论的重点了。   举两个代码栗子来说明二维数组在CUDA中的使用(亲测可用): 1....普通二维数组示例: 输入:二维数组A(8行4列) 输出:二维数组C(8行4列) 函数功能:将数组A中的每一个元素加上10,并保存到C中对应位置。   ...这个是一个简单的示例,以一级指针二级指针开访问二维数组中的数据,主要步骤如下: (1)为二级指针A、C和一级指针dataA、dataC分配CPU内存。二级指针指向的内存中保存的是一级指针的地址。...(3)通过主机端一级指针dataA将输入数据保存到CPU中的二维数组中。 (4)关键一步:将设备端一级指针的地址,保存到主机端二级指针指向的CPU内存中。

    3.2K70

    二维数组指针复习

    最近在练习C语言计算机二级的程序设计题,碰到了二维数组指针的结合,当时怎么调试都不对,自己也记不清楚该怎么用了就跑去看书翻资料重新复习。...本次复习看的讲解:点击访问 自己纠结的问题是二维数组 int a[3][4]的数组名是二级指针吗?...答案不是,而在上面的复习讲解上说是地址的地址是错的(但是他的讲解确实很让人懂二维数组的使用), a退化为指针后,类型为int (*)[4],该指针指向含4个int类型元素的一维数组。...&a+1和&a差值为48,正好是二维数组的长度(4(int长度)X3X4=48),+1是加了一个二维数组长度。...(摘自讲解中的话),因此我们只要找到令指针指向二维数组的首地址就能通过顺序来找到接下的元素。

    37610

    【C 语言】二级指针作为输入 ( 指针数组 | 复杂指针解读 )

    文章目录 一、指针数组 二、复杂指针解读 三、数组指针代码示例 一、指针数组 ---- 定义一个数组指针 : 数组中的 元素 是 指向 字符串的指针 , 即 每个数组元素 只有 4 字节 ; char...指针步长 | 复杂指针阅读技巧 ) 【C 语言】指针数组 ( 指针 | 数组 | 指针运算 | 数组访问方式 | 字符串 | 指针数组 | 数组指针 | 多维数组 | 多维指针 | 数组参数 |...发现是 char , 说明指针指向的数据是 char 类型 * * array 是一个数组 , 数组中的元素的 char * 字符串 * * 这是 指针数组 ,...数组元素 是 指针 */ char *array[] = {"abc", "123", "258", "sfd"}; 这是 指针数组 , 数组元素 是 指针 三、数组指针代码示例 --...发现是 char , 说明指针指向的数据是 char 类型 * * array 是一个数组 , 数组中的元素的 char * 字符串 * * 这是 指针数组 ,

    45420
    领券