前言 C语言函数里最常用就是指针传参和返回地址,特别是字符串处理中,经常需要封装各种功能函数完成数据处理,并且C语言标准库里也提供了string.h 头文件,里面包含了很多字符串处理函数;这些函数的参数和返回值几乎都是指针类型...func(&a,&b); //func(100,200) printf("a=%d,b=%d\n",a,b); return 0; } void func(int *a,int *b) { int c;...c=*a; *a=*b; *b=c; } //return语句只能返回一个值 //如果函数想返回多个值,可以使用指针(形参)实现。...注意: 从大到小或者小到大排序可以通过函数形参区分。...='\0'){} return str-p-1; } /* 函数功能: 实现字符串排序.支持从小到大或者大到小 函数形参: char *p 将要排序的字符串 char flag 选择排序方式
形参则是你在写一个被调函数时,为了说明用到的自变量的类型、要进行什么操作而定义的,在调用函数前它不会被分配内存空间,更不会被赋予具体的值。...调用函数时,形参会被分配一个新的内存空间,实参的值就会被“复制”进去,让它在被调函数中参与运算。而实参本身不参与这个运算,它仅仅起到一个传递值的作用(不过在C++中可以用&改变实参的值)。
文章目录 一、一维数组形参退化 二、二维数组形参退化 三、数组形参等价关系 一、一维数组形参退化 ---- C 中将 一维数组 作为参数 , 传递到函数中 , 该 一维数组 会退化为 指针 ; 将 int..., 函数中处理 array 数组时 , 不知道该数组的元素个数 , 编译器只能确认 , 该参数是一个 int * 指针类型 ; 这样操作是为了提高 编译器 的效率 , 提高程序执行的效率 , 函数的 形参...array[] void fun(int array[]) { } int *array void fun(int *array) { } 二、二维数组形参退化 ---- 二维数组 作为 函数形参 ,...也是 指针 , 则形参为 二级指针 ; 实参为 二维数组 int array[10][20] , 等效的 形参为 一级指针 int (*array)[20] ; 二维数组 的 数组的元素 是 一维数组...; 外围数组 ( 第二维 ) 退化为 指针 , 指针 指向的元素 是 一维数组 , 则形参为 指向 一维数组 的指针 , 每个一维数组有 20 个元素 ;
数组元素的值做实参 数组元素作为实参时,将数组元素的值传递给形参,传递的方向是从实参向形参的单向值传递。 例:编写函数求一维数组的最大值。...a:b; } 数组名称做形参 当数组作为形参时,虽然形式上还是数组,比如void sort(int arr[ ]),但是并不意味着真正建立了一个包含和实参数组大小相同的数组,在调用函数时也不对它分配存储单元...} return 0; } void fun(int a[]){ for(int i=0;i<=9;i++) a[i]=a[i]+10; } 注意: 用数组元素做实参时...,向形参变量传递的是数组元素的值 用数组名做函数实参时,向形参传递的是数组首元素的地址。...数组名作为函数实参传递时,函数定义处作为接收参数的数组类型形参既可以指定长度也可以不指定长度。 数组元素作为函数实参传递时,数组元素类型必须与形参数据类型一致 。
指针数组做main形参 2.1 int main(int argc, char *argv[]); 指针数组的一个重要应用是做main函数的形参。...return 0; } /*输出 Number of command line arguments: 1 Argument 0: D:\Program Files\code\CC++程序集合\c\...【谭浩强】C语言自学\output\mytest.exe */
一、什么是联合体? 在C语言中,变量的定义是分配存储空间的过程。一般的,每个变量都具有其独有的存储空间,那么可不可以在同一个内存空间中存储不同的数据类型(不是同事存储)呢?...答案是可以的,使用联合体就可以达到这样的目的。联合体也叫共用体,在C语言中定义联合体的关键字是union。...关于结构体与枚举的知识可查看往期笔记: 【C语言笔记】结构体 【C语言笔记】枚举 二、联合体变量的定义方法 创建联合和创建结构的方式相同,需要一个联合模板和联合变量。...关于typedef关键字可查看往期笔记:【C语言笔记】#define与typedef的区别? 三、初始化联合体 联合体的初始化与结构体不同,联合体只能存储一个值。...*/ 四、联合体的应用示例 1、检测当前处理器是大端模式还是小端模式? 之前分享的《什么是大小端模式?》中已经有介绍怎么判断当前处理器的大小端问题: ? 现在,可以使用联合体来做判断: ?
文章目录 导引 指针函数 指针函数定义 指针函数的三种写法 代码示例 函数指针 定义 代码示例 函数指针和指针函数区别 定义不同 写法不同 用法不同 导引 函数指针和指针函数,在学习 C 语言的时候遇到这两个东西简直头疼...,当然还有更头疼的,比如什么函数指针函数、指针函数指针、数组指针、指针数组、函数指针数组等等,描述越长其定义就越复杂,当然理解起来就越难,特别是刚开始学习这门语言的童鞋,估计碰到这些东西就已经要崩溃了,
(即:给联合体其中的一个成员赋值,其他成员的值也会跟着被改变) 二,联合体的声明 1,联合体类型的声明 C语言中联合体类型的定义形式: union 联合体名 { 成员项表列 }; 例如:...(我们定义一个同时由char和int型构成的联合体) union Un { char c; int i; }; (注意:分号不能丢) 2,联合体变量的创建 同结构体变量的创建类似,我们可以在声明联合体类型的同时创建变量...2)在声明联合体类型的同时创建变量 union Un { char c; int i; }u1; 对联合体成员的引用也与对结构体成员的引用相同 三,联合体的特点 1,联合体与结构体的对比 联合体的大部分与结构体相似...下面我们就对联合体u1中的成员c进行赋值,然后再打印成员i #include union Un { char c; int i; }u1; int main() { u1.c...= 1; printf("%d", u1.i); return 0; } 运行结果: 可见:尽管没有给成员i赋值,但是随着成员c被修改成员i的值也发生了变化 四,联合体的大小 上面提到的联合体
1.联合体的含义 联合体也叫做共用体,是指联合体的所有成员共用同一块内存空间。这也就说明了,联合体的大小至少是其成员所占空间的最大值。 2....联合体的声明 #include //声明了一个联合体 union Un { char c; int i; }; int main() { //联合变量的定义 union Un...联合体大小的计算 联合体的大小至少是最大成员的大小。 当最大成员大小不是最大对齐数的整数倍的时候,就要对齐到最大对齐数的整数倍。 4....联合体的特点 联合体的成员时共用同一块内存空间的,这样一个联合体变量的大小,至少得是最大成员的大小(因为联合体至少得有能力保存最大的那个成员)。 如何证明这一点呢?
C++问题: 使用函数调用,排序string字符串数组从小到大,没有使用指针和引用,为什么实参也会改变?...string> using namespace std; int main() { void sort(string []); string array[3] = {"l" , "love" , "c+...{ if(s[j + 1] < s[j]) { temp = s[j]; s[j] = s[j+1]; s[j+1] = temp; } } } } 改变的值是实参的值,也就是说实参对形参传的是地址...,此时形参与实参为同一个地址,形参在改变形参也会改变,所以string类与数组做形参时一样,string类的形参是一个指针,接受的是字符串首个字符地址,其中数组类型在存贮数据是连续线性存贮的,而string...这是关于C++中string类比C语言中数组类型的改进。
不带形参的main函数一般写成: int main() 或 int main(void) 表示mian函数没有参数,调用mian函数时不需要给出实参。...而main函数有形参的形式: int main( int argc, char** argv) int main( int argc, char *argv[]) 我是这样理解这两种方式,其中第一种方式
( "%x\n" , un.i); return 0 ; } 输出结果:11223355 由图可知是将最低位由于联合体的特点,覆盖成c的55。...; } 输出结果: 001 AF85C 001 AF85C 001 AF85C 可见输出结果一样,这也就说明联合体地址和里面每个成员名的地址是一样的 1.3...我们认识了联合体,那我们是不是又有一种巧妙的方式判断大小端了 int check_sys () { union { int i; char c;...枚举类型 枚举是 C 语言中的一种基本数据类型,用于定义一组具有离散值的常量 2.1 枚举类型的声明 枚举顾名思义就是一 一列举。 把可能的取值一 一列举。...在C语言中是可以的,但是在C++是不行的,C++的类型检查比较严格。
文章目录 一、多维数组做函数形参退化为指针过程 1、使用 int array[2][3] 作函数参数 2、使用 int array[][3] 作函数参数 3、使用 int (*array)[3] 作函数参数...一、多维数组做函数形参退化为指针过程 ---- 一维数组 作为 函数参数时 , 会退化为指针 ; 解决方案是 传入 数组首地址 和 数组元素个数 ; 如果 多维数组 作为 函数参数时 , 也存在退化问题
防止了命名污染(封装) 便于调试 使用方便,一次可以定义多个常量 联合体(共用体) 联合体的定义 联合也是一种特殊的自定义类型 这种类型定义的变量也包含一系列的成员,特征是这些成员公用同一块空间 (所以联合体也叫共用体...) 联合体的特点 //联合类型的声明 union Un { char c; int i; }; //联合变量的定义 union Un un; //计算联合变量的大小 printf("%d\n", sizeof...(un)); 联合体的变量是共用同一块空间的 联合体的计算 联合的成员是共用同一块内存空间的,这样一个联合变量的大小,至少是最大成员的大小(因为联合体至少得有能力保存最大的那个成员)。...以上就是自定义类型中的枚举和联合体的介绍以及用法解释,自定义类型的使用是十分灵活的,需要我们好好领悟,要是文章有哪些错误,希望各位在评论区可以指正,我们一起进步!
首先我们限定一下问题,只限于cdecl的调用约定,函数没有被编译器做inline的优化(C++才有inline,但是C编译器也可能自己把函数调用优化掉)。...除了cdecl以外,C中其他常用的调用约定包括stdcall和fastcall,C++中还有一个thiscall(用于调用类的成员函数)。fastcall会使用寄存器来传递一部分参数。...而且C语言也不支持传递引用作为参数。 纠结的在于传递数组作为参数这种情况,对编译器来说,实际上的参数是个指针,但是从代码形式上来看形参好像是个数组……这个我也不知道该怎么算,这简直是个哲学问题。...这个时候显然不是“实参和形参各占用独立的存储单元”。...使用寄存器传参数的时候,按照传统的占用存储的说法就不合适了,不过由于这些寄存器都是易失的,用于传参之后寄存器里原来的值必须先保存到堆栈上,也可以相当于占用了相应的存储空间,前面的讨论仍然是适用的。
: 我们如果在函数外部使用函数形参,这是不可行的。...2.形参在函数调用过程中才实例化(分配内存单元) 函数调用之前,形参还未创建 函数调用过程中,形参才被实例化 函数调用结束,形参生命周期结束,被销毁 三.形参与实参的关系 了解了什么是函数的形参和实参,...他们的关系是: 形参实例化之后其实相当于实参的一份临时拷贝。 这里我们对函数的实参和形参进行分析: 我们来尝试写一个函数交换两个整形变量的内容。...这是因为在函数调用时,形参x,y是实参num1,num2的一份临时拷贝,形参和实参并没有建立真正意义上的联系,形参x,y是两个独立的变量,和实参num1,num2分别占用不同的内存空间,在这里,形参和实参只是数值相同罢了...: 形参实例化之后其实相当于实参的一份临时拷贝。
文章目录 一、字符串翻转模型 业务函数 二、完整代码示例 一、字符串翻转模型 业务函数 ---- 将上一篇博客 【C 语言】字符串模型 ( 字符串翻转模型 ) 的代码 , 主要业务逻辑 , 抽象成函数...; 字符串翻转模型 业务函数 要点 : 形参返回值 : 函数的返回值 , 一般使用 函数形参 间接赋值 进行返回 ; 下面的代码中 char *str 是返回值 ; int inverse(char *...str) 函数返回值 : 函数的返回值 , 反映的是函数的执行结果状态 , 返回 0 执行成功 , 返回 -1 执行失败 ; 函数形参处理 : 在 函数中 , 如果涉及到修改 形参 指针变量 , 一般不直接使用形参..., 创建一个临时局部变量 , 接收形参 , 然后再执行相关操作 ; // 创建临时变量接收 函数形参 , 不要直接改变形参的函数指向 char *str_tmp = str; 形参指针判空...: 函数的第一项任务就是 判定 形参指针是否合法 , 如果任何一个指针为空 , 直接返回 -1 ; // 判断传入的字符串指针是否为空 if(str_tmp == NULL)
, 进行 翻转 , 逆序 等操作 ; 字符串翻转模型 : 借助 指针 进行翻转 , 或 借助 栈 后进先出的特性 , 进行 翻转 ; 一、业务子函数接口定义要点 ---- 在上一篇博客 【C...语言】字符串模型 ( strstr-while 模型 ) 的基础上 , 将相关功能封装成 API 函数 , 将 主函数 与 子业务 函数分离开 ; 自定义函数接口 ; 分离 自定义的 业务子函数 与 主函数...main() ; 定义的接口如下 : 要点 1 形参指针间接赋值 : 主要是获取子串大小 , 通过 int *sub_count 参数的 间接赋值 , 实现函数结果返回 ; 要点 2 返回值状态...: 定义 局部 临时 指针变量 , 接收 函数形参变量 , 尽量不修改 函数 形参 的值 ; 形参指针判空 : 凡是传入的指针 , 一律判定指针是否合法 ; 形参返回值处理 : 返回值不要直接修改 ,..., 失败返回失败代码 */ int get_sub_count(char *main_str, char *sub_str, int *sub_count) { // 为了不修改 函数 形参
现在,小编将枚举和联合体笔记分享给大家。枚举和联合体与结构体一样,都是自定义类型,在学习完枚举和联合体后,C语言中自定义类型也就告一段落啦。...联合体 概述 联合体也是自定义类型,关键字为union,特点是所有成员共⽤同⼀块内存空间,因此,联合体也叫做共用体。...联合体大小的计算 • 联合的⼤⼩⾄少是最⼤成员的⼤⼩。...因此,输出结果为16 总结: 联合体大小不是最大成员的大小 优点 使用联合体可以节省一定的空间 HAUE某学院学生会需举办活动,要上线⼀个礼品兑换单,礼品兑换单中有三种商品:图书、杯⼦、衬衫。...在C语⾔中是可以的,但是在C++是不⾏的,C++的类型检查⽐较严格。
领取专属 10元无门槛券
手把手带您无忧上云