【进阶指针一】字符指针&指针数组&数组指针 https://blog.csdn.net/qq_64428099/article/details/125011487 目录 1.数组传参 1-2 二维数组传参... 2 指针传参 2-1 一级指针传参 2-2 二级指针传参 2-3 关于传&arr和arr 3 函数指针 3-1 函数指针的引入 3-2 函数指针的脱裤子放屁使用【先见一见基本操作】 3-3 试图看懂大佬写的代码... 4 函数指针数组 4-1函数指针数组的引入和基本使用 4-2 函数指针数组的妙用 ---- 1.数组传参 1-1一维数组传参 正向:实参给定,猜猜看形参可以怎么写?...我们所知的复合类型(比如数组,结构体等)的类型名都是首元素的地址(两个特殊情况除外)。 2. 对于多维数组定义或者传参时,只有第一维数组的数组元素可以省略,其余维必须写上,且必须写对!!!...2 指针传参 反向:形参给定,猜猜看实参可以怎么写?
/***************** 结构体数组 计算一个班学生四门课程平均分 ************************/ #include #include <string.h
:当你在写函数时,如果你想让函数操作一个数组,你可以将数组的指针作为函数的参数传递。...三、字符指针 字符指针,它指向一个字符数组或字符串。 用途 1、动态内存分配:字符指针可以用于动态内存分配,这在处理变长字符串或其他数据结构时非常有用。...四、二维数组传参,形参写二维数组 1、为什么一维数组传参,形参可以是数组,也可以是指针?...1.写成数组更加直观,为了方便理解 2.写成指针传参是因为数组传参,传递的是数组的第一个元素的地址 二维数组传参,形参写成数组也是可以的,非常直观,容易理解 2、形参能写成指针吗?...:在很多情况下,我们需要将一个函数作为参数传递给另一个函数。
一、结构体数组 (1)定义 ①struct 结构体名 {成员列表} 数组名 [数组长度] ②先声明一个结构体类型,然后再用此类型定义结构体数组 结构体类 数组名[数组长度] 二、结构体指针 指向结构体对象的指针变量既可以指向结构体变量...,也可指向结构体数组中的元素。...指针变量的基类型必须与结构体变量的类型相同 将一个结构体变量的值传递给另一函数的方法 ①用结构体变量的值传递给另一个函数 ②用结构体变量作实参 ③用指向结构体变量的指针作实参,将结构体变量的地址传给形参
1.首先,arr被解析为指向数组首元素的指针。在内存中,数组的元素是连续存储的,而数组名实际上是一个指向数组首元素的指针。因此,通过arr可以找到数组的起始位置。...3.arr[i]中的[]是索引运算符,用于访问数组中的元素。它表示将数组名arr解析为指向数组首元素的指针,并使用索引i进行偏移,以访问数组中第i个元素的值。...数组传参的时候形参是不会创建数组的,实际上传的是首元素的地址,发生了数组降级 void test(int arr[]) //int *arr { int sz = sizeof(arr) / sizeof...//test(arr);//这里的数组名就是数组首元素地址 Print(arr,sz); return 0; } 六、传址调用和传值调用 传值调用:传的是变量,传值调用 int Add...//数组名是数组首元素的地址 printf("%zd\n", len); return 0; } 6.2为什么有传址和传值两种调用方式 因为有一些问题是不使用指针无法解决的!!!
比如 char *p=”sdflkjasljfsjlsdfsa”; char p1[200]; 将p赋给p1 (1)strcpy(p1,p); (2)char *src=”helloworld
通过结构体数组给定 3 个学生的信息。信息包括:学号,姓名,成绩,找出成绩最高的学生的所有信息。...;i<=4;i++){ printf("%d %s %f\n",a[i].name,a[i].name,a[i].score); } return 0; } 有3个学生结构体变量
* a, int length) { int* p, temp, * i, * j, m; m = (length - 1) / 2;//取得中间的下标 i = a;//i指向数组的首元素...j = a + length - 1;//j指向数组的尾元素 p = a + m;//p指向数组中间的元素 for(; i < p; i++,j--) {//依次交换首尾元素的值...main() { int a[5] = { 1,2,3,4,5 }; int length = sizeof(a) / sizeof(a[0]); printf("反转之前的数组...:\n"); printArr(a, length); reverse(a, length); printf("反转之后的数组:\n"); printArr(a, length
在一次稀疏矩阵压缩算法中,为了保证压缩函数可复用性,使用了void** 作为压缩形参,结果二维数组传入一直无法获取到内容。...结果出现的方案如下 方法1 方法2: 数组指针 或者是 二级指针 结果相同 int ** arr; 上述两种情况指针步长都会是一个int* 的大小,也就是4个字节 ,这个可以从第二章图,13630500
结构体数组 (1) 结构体数组声明初始化 声明结构体数组 : -- 声明结构体的时候声明结构体数组 : 格式为 : struct 结构标记 {} 数组名[]; -- 使用结构标记声明结构体数组 :...* 同时也声明结构体类型数组 * 为数组初始化 * 直接将每个结构体成员的值依次列出即可 */ struct student { char *name; int age; } team1...high 和 low : 其中 low 是首元素的 首地址, high 是 尾元素的尾地址, 只有这样 它们的差的 0.5 倍才是准确的中值的首地址; 指针指向数组注意点 : 不要生成非法的指针, 指针不能指向数组之外的元素...: * struct key tab * 是指向结构体数组指针, 该指针可以操作结构体数组 */ struct key *binsearch(char *word, struct key *...; 指针 p 指向 结构体数组, 如果 p + 1 , 结果是 p 地址 加上 结构体所占内存大小; 结构体大小 : 结构体的大小不是完全等于各个成员的长度之和, 对象之间有对齐要求; -- 空穴 :
结构中的字符数组和字符指针 一般情况下我们在结构中都使用字符数组来存储字符串,是否可以使用指向char的指针来代替字符数组呢?...pnames treas = {"hig","klm"};//字符串全部存储在编译器存储常量的地方(特别注意,是利用指针定义的数组,不是之前定义好的) #define LEN 20 struct pnames...{ char *first; char *last; } struct pnames treas = {"hig","klm"}; names结构体中的字符串存放在结构体内部,结构体需要分配40个字节存储姓名...struct pnames结构体不需要为字符串分配任何存储空间,它使用的是存储在别的地方的字符串,指针只提供操作的可能。...有关结构体中字符数组的其他的用法: 可以使用malloc分配内存并使用指针储存该地址。(详见C Primer Plus P459)
一、实验目的 1、复习 C 语言中函数、数组、指针、结构体与共用体等的概念。 2、熟悉利用 C 语言进行程序设计的一般方法。...2、 数组:把具有相同类型的若干变量按有序的形式组织起来的整体。 3、指针:存储器的一个字节称为一个内存单元,内存单元的编号也叫做地址,于是这个地址就叫做指针。...4、结构体:由若干成员组成的构造类型,内存占用为整体。 5、共用体:由若干成员组成的构造类型,内存占用为最大的一个成员。...break; if(j==M) printf("%d,%d,%d\n",a[i][k],i,k); } return 0; }运行结果: 4、 调试程序:利用指针输出二维数组的元素...实验五: 代码将结构体中使用共用体,可以灵活的根据职业的不同来选择不同地点。 class是用来定义类,不可以作为变量名 五、教师评语
指向结构体变量的指针 指向结构体对象的指针变量既可以指向结构体变量,也可以用来指向结构体数组中的元素。...可以用指针变量指向结构体数组的元素。...结构体作为函数参数 对结构体数据操作时,常常需要将结构体变量的成员、结构体变量、结构体数组名或结构体指针作为参数 传递给另一个函数。...例如: 用 stu[1].num 或 stu[2].name 作函数实参,将实参值传给形参。 2.用结构体变量作实参 用结构体变量作实参时,将结构体变量所占的内存单元的内容全部按顺序传递给形参。...3.用指向结构体变量(或数组元素)的指针作实参 用指向结构体变量(或数组元素)的指针作实参时,将结构体变量(或数组元素)的地址传递给形参。 结构体与函数之间的关系主要是: 1.结构体作为函数的参数。
文章目录 一、将结构体写出到文件中并读取结构体数据 二、将结构体数组写出到文件中并读取结构体数组数据 一、将结构体写出到文件中并读取结构体数据 ---- 写出结构体 : 直接将结构体指针指向的 , 结构体大小的内存...1, sizeof (struct student), p); 读取结构体 : 直接读取文件数据 , 使用结构体指针接收该数据 , 便可以自动为结构体填充数据 ; // 存储读取到的结构体数据..., age=%d\n", s2.name, s2.age); return 0; } 执行结果 : 写出的文件字节数为 24 , 20 字节的字符串数据 , 4 字节 int 值 ; 二、将结构体数组写出到文件中并读取结构体数组数据...---- 保存结构体数组 : 给定结构体指针设置要写出文件的数据 , 设置好写出的文件字节数即可 ; // 要写入文件的结构体 struct student s1[2] = {{"Tom...", 18}, {"Jerry", 20}}; // 将结构体写出到文件中 fwrite(s1, 2, sizeof (struct student), p); 读取结构体数组 : 给定接收数据的结构体指针
,stud.name,stud.score[0],stud.score[1],stud.score[2],stud.aver); getchar(); } 程序运行结果如下: 定义一个结构体...,只是结构体是将不同类型组合后形成的一个用户自己定义的数据结构。...结构体变量: 该程序定义了一个结构体数组和一个结构体指针,就像数组和指针的定义一样,需要说明数组和指针的类型,数组就是可以存放什么类型的数据,指针是可以指向什么类型的数据。...struct Student stu[3]; struct Student *p=stu; 用结构体变量和结构体变量的指针做函数的参数: 定义结构体指针p,并初始化它让他指向结构体数组stu的首地址...input函数形参为结构体数组,实参为结构体指针。 max函数形参为结构体数组,实参为结构体指针。 print函数形参是结构体变量,实参是结构体变量(是结构体数组元素)。
文章目录 一、打印 指针数组 中指针指向的字符串 二、字符串排序 三、代码示例 一、打印 指针数组 中指针指向的字符串 ---- 打印 指针数组 中指针指向的字符串 : 指针退化问题 : 传入二级指针..., 同时还要传入 一级指针的个数 ; 实参是 指针数组 , 形参 退化为 二级指针 , 需要人为指定 数组的元素个数 ; 验证指针合法性 : 函数中 , 只要是指针 , 就有可能为 NULL , 函数入口就要验证该指针合法性...[i]); printf("%s\n", *(array + i)); } return 0; } 二、字符串排序 ---- 将 指针数组 作为参数 , 传入函数中 ;...发现是 char , 说明指针指向的数据是 char 类型 * * array 是一个数组 , 数组中的元素的 char * 字符串 * * 这是 指针数组 ,...) / sizeof(array[0]); // 打印数组 printf_array(array, num); // 对 指针数组 进行排序 , 排序依据是 指针 指向的数据对比
本文将再论函数,主要介绍指针、数组、结构体等作参数;函数值返回指针、结构体,以及C语言作用域相关知识。...在函数内部,通过解引用指针并修改指针所指向的值,实现了对实参的修改。 9.1.3 数组作参数 在C语言中,数组名实际上是一个指针,表示数组首元素的地址。...因此,当将数组名作为实参传递给函数时,实际上传递的是数组名的指针值。 在函数调用时,数组名作为实参传递给函数的形参,只传递了数组名的值,也就是数组的首地址。...然后,调用printPoint函数,将point作为参数传递给它。 输出: b....在main函数中,调用printPoint函数,将&point(point的地址)作为参数传递给它 输出结果与方法a相同: 9.2 函数值 9.2.1 返回指针值 函数可以返回指针作为其返回值
为了在程序运行过程中,将两个结构体数组合并成一个大的结构体,在节省空间的基础上,我使用一个大的结构体指针数组,来将其元素分别指向结构体数组中的结构体。...实现过程中,发现这个结构体指针数组的大小是不能确定的,所以使用变长数组来声明,由于gcc编译器未支持C99标准,所以编译无法通过。 进而,我使用malloc来在运行过程中分配内存。...「指针数组」 定义 int *p[n]; []优先级高,先与p结合成为一个数组,再由int*说明这是一个整型指针数组,它有n个指针类型的数组元素。...数组指针只是一个指针变量,似乎是C语言里专门用来指向二维数组的,它占有内存中一个指针的存储空间。 指针数组是多个指针变量,以数组形式存在内存当中,占有多个指针的存储空间。...它是“储存指针的数组”的简称。 数组指针:首先它是一个指针,它指向一个数组。在32 位系统下任何类型的指针永远是占4 个字节,至于它指向的数组占多少字节,不知道,具体要看数组大小。
从数组的第一个元素开始,向后遍历,如何当前元素的值等于val的值,就删除。 怎么删呢? 将后面的元素,依次向前移动,将要删除的元素覆盖掉。...后面也是如此,直至将数组中所有值等于val的元素都删除掉,就完成了。 那大家思考一下,这个方法好不好?...然后再判断两指针指向的元素是否相等,重复上述操作,直至src遍历完数组。 最终dest+1就是去重后的数组长度。...其实用双指针的方法还可以搞定,举个例子: 假如现在有这样两个数组: 如何合并?...两个指针分别指向两数组第一个元素,再开辟一个新数组,对他们进行比较,依次取较小的那个元素放到新数组中,如果相等,任选一个放入。 但是,对于这个题,这种方法可行吗? 显然是不可行的。
与传值调用不同,传址调用会将变量的地址传递给函数,这样函数就能够直接修改原始变量的值。在传址调用中,传递的是变量的指针,函数通过指针访问并修改原始变量的内容。 2....缺点: 传递大数据(如大数组或结构体)时会产生较大的内存开销,因为函数接收的是参数的副本。 2....传址调用的优缺点: 优点: 通过传递指针,可以直接修改外部变量,适用于需要在函数内修改外部变量的场景。 对于大数据(如数组、结构体等),传址调用比传值调用更高效,因为不需要复制大量的数据。...传址调用:当需要修改传入的参数,或者当参数较大(如数组、结构体等)时,传址调用更为高效。 小结 通过上述分析,我们深入探讨了C语言中两种常见的参数传递方式:传值调用和传址调用。...传值调用将参数的副本传递给函数,适用于不需要修改外部变量的情况。 传址调用则通过传递地址,使得函数能够直接修改外部变量,适用于需要修改变量的场景,尤其是在处理大数据时更为高效。