项目日报开发表 | |
项目名称 | 苏嵌实训——嵌入式LinuxC第七天 |
今日进度以及任务 | 1:总结今日内容 2:复习链表(单链表) |
本日任务完成情况 | 函数: 函数定义由两部分组成:函数首部和函数操作描述 函数调用是通过表达式或语句激活并执行函数代码的过程 参数
形参列表 如果没有,则写成void 声明 所谓声明,就是告诉编译器我要使用这个函数,你现在没有找到它的定义不要紧,请不要报错,稍后我会把定义补上。 函数声明的格式非常简单,相当于去掉函数定义中的函数体再加上分号;,如下所示: 返回值类型 函数名( 类型 形参, 类型 形参… ); 也可以不写形参,只写数据类型: 函数声明给出了函数名、返回值类型、参数列表(参数类型)等与该函数有关的信息,称为函数原型。 函数原型的作用是告诉编译器与该函数有关的信息,让编译器知道函数的存在,以及存在的形式,即使函数暂时没有定义,编译器也知道如何使用它。 传值参数 调用函数时,实参表达式的值被复制到相应形参标识的对象中, 函数返回值通过匿名对象传递 内存管理:计算机中的内存是分区来管理的,程序和程序之间的内存是独立的,不能互相访问 代码区: 栈区:
如果不及时销毁,会造成内存泄漏等情况。 A基本类型 (1)char:声明字符型变量或函数 (2)int:声明整型变量或函数 (3)float:声明浮点型变量或函数 (4) double:声明双精度变量或函数 B修饰类型 (5)short:声明短整型变量或函数 (6)long:声明长整型变量或函数 (7)signed:声明有符号类型变量 (8)unsigned:声明无符号类型变量 C构造类型 (9)enum:声明枚举类型 (10)union:声明共用体(联合)数据类型 (11)struct:声明结构体变量或函数 复合数据类型: 一、结构体 1.作用:封装数据,把多种不同的数据类型放在一起 2.定义:一般放在全局,定义时不要忘记在结尾的“}”后加上“;” 3.初始化 分为静态初始化和动态初始化 在动态初始化时要注意: ①给结构体中的数组成员赋值时,不能直接将字符串赋给数组名,可以使用strcpy函数 ②给结构体中的指针变量成员赋值时,要先给指针分配空间,否则它会使一个野指针 静态初始化即在定义的时候直接赋值 结构体数组的初始化:使用for循环来完成 4.结构体中的对齐方式:字对齐和半字对齐 字对齐:给每个变量先分配四个字节的空间,如果下一个数据的数据类型与之相同,就可以放在一起,如果空间不够就再开辟四个字节的空间;如果类型不相同,就直接开辟四个字节的空间 半字对齐:原理和字对齐大致相同,但是分配的空间为2个字节 内存空洞:由于字对齐和半字对齐造成的内存浪费 二、共用体 1.和结构体的区别 2.使用共用体会造成数据覆盖 3.大端字节和小段字节 大端字节和小段字节是CPU的属性,与操作系统无关 小端字节:低字节存放在低地址,高字节存放在高地址 无论大端字节还是小端字节,都是从低字节开始存放的 使用共用体来验证CPU的大小端 |
本日开发中出现的问题汇总 | 软件版本有时会报错或缺失某些内容 |
本日未解决问题 | 枚举变量 |
本日开发收获 | 函数,内存管理,关键字 |
其他 |