文章目录

    • 第一话——数字电路
      • 1.1、电平特性
        • 1.1.1、简述TTL电平和CMOS电平
      • 1.2、进制的认识和转换
        • 1.2.1、单片机中常见的二进制和十六进制
      • 1.3、二进制的逻辑运算
        • 1.3.1、与运算、或运算、非运算、同或运算、异或运算
    • 第二话——C语言基础
      • 2.1.1、C51数据类型
        • 2.2.1.1、基本数据类型
        • 2.2.1.2、扩充数据类型
      • ⛵2.2.2、运算量
        • 2.2.2.1、常量
        • 2.2.2.2、变量
      • 2.2.3、运算符
        • 2.2.3.1、赋值运算符
        • 2.2.3.2、算术运算符
        • 2.2.3.3 关系运算符
        • 2.2.3.4、逻辑运算符
        • 2.2.3.5、位运算符
        • 2.2.3.6、复合赋值运算符
        • 2.2.3.7、逗号运算符
        • 2.2.3.8、条件运算符
        • 2.2.3.9、指针与地址运算符
      • 2.2.4、表达式及复合语句
        • 2.2.4.1、表达式语句
        • 2.2.4.2、复合语句
      • 2.2.5、基本结构和相关语句
        • 2.2.5.1、顺序结构
        • 2.2.5.2、选择结构
        • 2.2.5.3、循环结构
        • 2.2.5.4、break 和 continue 以及 return 语句
      • 2.2.6、函数
        • 2.2.6.1、函数的定义
        • ⛅2.2.6.2、自定义函数的声明
      • 2.2.7、构造数据类型
        • ⛄2.2.7.1、数组
    • 总结

第一话——数字电路

既然是搞硬件,面对的是开发板,肉眼可见的是电器元件和错综复杂的电路,那么具备一定的电路知识是必须的啦~。什么?以前学出心理阴影,害怕数电模电了,好巧嗷,我之前也是学出心理阴影了。

本篇博客只是浅浅的提一些基础的数电知识的,不会特别深奥喔~掌握我用红字标注的重点,其他的内容了,就当做常识和复习了

1.1、电平特性

重点是认识高低电平

数字电路中,电平只有两种:高电平和低电平
对于电平这儿,只需要记住一个点:0低1高,也就是,0代表低电平,1代表高电平。比如在开展寻迹的时候,就是通过高低电平来判断当前行走的路径是否在设定路线上

记住上面0低1高就好,剩下的内容了,当做常识过一遍,有个印象就好,倘若确实是遇到它了,心里也不会发怵,心平气和的奖励它们一个谷歌+百度

常用的逻辑电平还有很多,比如TTL、CMOS、LVTTL、RS-232、RS-485 等。

1.1.1、简述TTL电平和CMOS电平

重点1:知道什么是TTL、什么是CMOS;
重点2:知道什么是逻辑电平

目前应用最广泛的数字电路是TTL电路和CMOS电路:
TTL—Transistor-Transistor Logic 三极管-三极管逻辑

MOS—Metal-Oxide Semiconductor 金属氧化物半导体晶体管

CMOS—Complementary Metal-Oxide Semiconductor互补型金属氧化物半导体晶体管

1. TTL电路

TTL电路以双极型晶体管(三极管)为开关元件,所以又称双极型集成电路。双极型数字集成电路是利用电子和空穴两种不同极性的载流子进行电传导的器件。

它具有速度高(开关速度快)、驱动能力强等优点,但其功耗较大,集成度相对较低。

2. CMOS电路

CMOS电路是由绝缘场效应晶体管组成,由于只有一种载流子,因而是一种单极型晶体管集成电路。

它的主要优点是输入阻抗高、功耗低、抗干扰能力强且适合大规模集成。
特别是其主导产品CMOS集成电路有着特殊的优点,如静态功耗几乎为零,输出逻辑电平可为VDD或VSS,上升和下降时间处于同数量级等,因而CMOS集成电路产品已成为集成电路的主流之一。

3. 关于TTL电平 和 COMS电平

TTL 电平信号用的最多,这是因为数据表示通常采用二进制,+5V 等价于逻辑1,0V 等价于逻辑0; 这被称为TTL(晶体管-晶体管逻辑电平)信号系统。

CMOS 电平VCC 可达12V,CMOS 电路输出高电平约为0.9VCC,而输出低电平约为0.1VCC。CMOS电路中不使用的输入端不能悬空,否则会造成逻辑混乱。
另外,CMOS 集成电路电源电压可以在较大范围内变化,因而对电源的要求不像TTL集成电路那样严格。

TTL 电路和CMOS 电路的逻辑电平关系如下:

①VOH逻辑电平1 的输出电压
②VOL逻辑电平0 的输出电压
③VIH逻辑电平1 的输入电压
④VIL逻辑电平0 的输入电压

输出通常称为 VOH 和 VOL(电压输出高/低),输入称为 VIH 和 VIL(电压输入高和低)。
我自己的理解了,O是输出Output的缩写,H是High的缩写。同理,I是Input的缩写,L是Low的缩写。

1.2、进制的认识和转换

浅浅过一下有个印象,见到各种进制以后,知道它们就好

1.2.1、单片机中常见的二进制和十六进制

二进制的特点: 数字电路中只有两种电平特性,即高电平和低电平,这也就决定了数字电路中使用二进制。
十进制数应该都不陌生,“逢十进一,借一当十”是十进制数的特点。二进制了,“逢二进一,借一当二”便是二进制数的特点。


十六进制的特点: 十六进制与二进制大同小异,不同之处就是十六进制是“逢十六进一,借一当十六”。
还有一点特别之处需要注意,十进制的0-15表示成十六进制为0~9、A、B、C、D、E、F,即十进制的数字10 对应十六进制的A,十进制的数字11对应十六进制的B,以此类推。
我们一般在十六进制数的最后面加上后缀H,表示该数为十六进制数,如AH、DEH等。这里的字母不区分大小写,在C语言编程时要写成“0xa,0xde”,在数的最前面加上“0x”表示该数为十六进制数。


进制转换——有个大致的概念就好,实际开发的时候倘若模糊了,可以借助计算器,做过算法的同学了,看到进制转换应该是可以轻松解决的。

十进制和二进制的之间的转换了,我自己常用的的是方式去背32、16、 8、4、2、1,然后凑出来对应的十进制。比如1010,按照四位分别是8421的一一对应,对应的十进制就是10.

常规的进制的之间的转换
①十进制转二进制——除二取余,倒序排列

② 十进制转二进制——除十六取余,倒序排列

③ 借助计算器求进制之间的转换。

1.3、二进制的逻辑运算

1.3.1、与运算、或运算、非运算、同或运算、异或运算

① 与运算
与运算是实现两个位都为1时,结果才为1这种逻辑关系的一种运算。C语言中运算符为&,其运算规则如下:0&0=0,0&1=0(1&0=0),1&1=1。

C 语言中&&表示“按位与”运算,意思是变量之间按二进制位数对应关系一一进行与运算。 如(0101 0101)&&(1010 1010)=0000 0000,而上面阐述的&运算只是对单一位进行运算。

② 或运算
或运算是实现有1则1,两个位都为0时,结果才为0这种逻辑关系的一种运算。C语言中运算符为|,其运算规则如下:0|0=0,0|1=1(1|0=1),1|1=1。

C 语言中||表示按位或运算,意思是变量之间按二进制位数对应关系一一进行“或”运算。 如(0101 0101)||(1010 1010)=1111 1111,而上面 讲到的|运算只是对单一位进行运算。

③非运算
非运算是实现求反这种逻辑关系的一种运算。C 语言中运算符为“!”,其运算规则如下:!0=1,!1=0。

C 语言中 ~ 表示按位取反运算。如~0101 0101=1010 1010,而上面讲到的“!”运算只是对单一位进行运算。

④同或运算
同或”与“异或”运算使用的较少,我们在这里只做简单了解,大家用到之处可再查找相关资料。“同或”运算是实现“必须相同,否则就没有”这种逻辑关系的一种运算,其逻辑运算符为“⊙”。其运算规则如下:
0⊙0=1,0⊙1=0(1⊙0=0),1⊙1=1。

在C 语言中没有规定符号。

⑤异或运算
异或运算是实现两个位相同为0,相异为1这种逻辑关系的一种运算,其逻辑运算符为“⊕”。其运算规则如下:0⊕0=0,0⊕1=1(1⊕0=1),1⊕1=0。
在C 语言中有“按位异或”运算“^”。Tips:异或运算在算法也被称为“半加运算”,即不考虑进位的加法

第二话——C语言基础

浅浅的带大家复习一下可爱的C语言吧,51单片机中使用的是C51,总体上了,其实和常规的C语言差不多的,只是有个别的不同,大致浏览一遍,就想想自己梦回大一在第一节计算机课,跟着老师敲着hello world

2.1.1、C51数据类型

先总览一下C语言包含的数据类型叭~

后面的阐述也大致是围绕这个图展开的了

2.2.1.1、基本数据类型

我相信看我这篇文章的小伙伴都是有一定的编程基础的了,那么我就不像教科书一样,逐一阐述各个基本的数据类型的意思,放一张总结的图在这儿,起到一个温故而知新的作用吧。然后提一下需要注意的点。

C语言一样,C51中也是存在一定的隐式转换,转换规则如下:
bit→char→int→long→float→signed→unsigned
同样的,也是支持强制转换:
可以通过强制类型转换符“()”对数据类型进行人为的强制转换。

在C 语言的书籍上还能看到有short int,long int,signed short int等数据类型,在单片机的C51中我们默认的规则如下: short int 即为int,long int 即为long,前面若无unsigned符号则一律认为是signed 型。

关于所占位数:
在编写程序时,无论是以十进制、十六进制还是二进制表示的数,在单片机中,所有的数据都是以二进制形式存储在存储器中的,既然是二进制,那么就只有两个数,0和1,这两个数每一个所占的空间就是1 位(bit),位也是单片机存储器中最小的单位。比位大的单位是字节(B),1 个字节等于8位(即1B=8b 或者写为 1Byte=8bit)。

关于float的精度损失: float 型和double 型是用来表示浮点数的,也就是带小数点的数,如12.345,0.213 等。

在一般的系统中,float 型数据只能提供7 位有效数字,double 型数据能够提供15~16 位有效数字。 由于float型变量只能接受7 位有效数字,因此最后3 位小数将会被四舍五入截掉,即实际a 的值将是123.1235。若将a 改成double型变量,则能全部接收上述10 位数字并存储在变量a 中。
小贴士:在算法竞赛中,为了防止float影响结果,建议都使用double。

2.2.1.2、扩充数据类型

单片机内部有很多的特殊功能寄存器,每个寄存器在单片机内部都分配有唯一的地址,一般我们会根据寄存器功能不同给寄存器赋予各自的名称,当我们需要在程序中操作这些特殊功能寄存器时,必须要在程序的最前面将这些名称加以声明,声明的过程实际就是将这个寄存器在内存中的地址编号赋给这个名称,这样编译器在以后的程序中才可认识这些名称所对应的寄存器。

C51 扩充数据类型主要如下:

这些寄存器的声明已经完全被包含在51单片机的特殊功能寄存器声明头文件reg51.h中了。只需要大致有个概念就好,后面直接用就可以,倘若忘记了,使用搜索引擎的时候也能更精确的查找。

⛵2.2.2、运算量

2.2.2.1、常量

常量是指在程序执行过程中其值不能改变的量。在C51 中支持整型常量、浮点型常量、字符型常量和字符串型常量。

①整型常量
十进制整数。如234、-56、0 等。 十六进制整数。以0x 开头表示,如0x12 表示十六进制数12H。 长整数。在C51中当一个整数的值达到长整型的范围,则该数按长整型存放,在存储器中占四个字节,另外,如一个整数后面加一个字母L,这个数在存储器中也按长整型存放。如123L在存储器中占四个字节。

②浮点型常量
浮点型常量也就是实型常数。有十进制表示形式和指数表示形式。十进制表示形式又称定点表示形式,由数字和小数点组成。如0.123、34.645等都是十进制数表示形式的浮点型常量。指数表示形式为: [] 数字[.数字] e []数字。例如:123.456e-3、-3.123e2 等都是指数形式的浮点型常量。

③字符型常量
这个不太常用了,了解就好。 字符型常量是用单引号引起的字符,如‘a’、‘1’、‘F’等。可以是可显示的ASCII字符,也可以是不可显示的控制字符。对不可显示的控制字符须在前面加上反斜杠“\”组成转义字符。

④字符串型常量
字符串型常量由双引号“”括起的字符组成。如“D”、“1234”、“ABCD”等。注意字符串常量与字符常量是不一样,一个字符常量在计算机内只用一个字节存放,而一个字符串常量在内存中存放时不仅双引号内的字符一个占一个字节,而且系统会自动的在后面加一个转义字符“\0”作为字符串结束符。

2.2.2.2、变量

变量是在程序运行过程中其值可以改变的量。一个变量由两部分组成:变量名和变量值

在C51 中,变量在使用前必须对变量进行定义,指出变量的数据类型和存储模式。以便编译系统为它分配相应的存储单元。

常规的 数据类型说明符 变量名 = 初始值的形式大多数小伙伴应该都是比较熟悉的,稍微蒙一点的是这个可以根据自己开发需求而写的存储种类 和存储器类型叭~,稍安勿躁,马上介绍它们。

(1)、变量名
这里和C语言相差不大。 在C51 中规定变量名可以由字母、数字和下划线三种字符组成,且第一个位置必须为字母或下划线。变量名有两种:普通变量名和指针变量名。它们的区别是指针变量名前面要带 * 号。

(2)、typedef 起别名
有的时候,变量名太长了,比如:

(3)、存储种类
存储种类是指变量在程序执行过程中的作用范围。C51变量的存储种类有四种,分别是自动(auto)外部(extern)静态(static)寄存器(register)

①、auto: 使用auto 定义的变量称为自动变量,其作用范围在定义它的函数体或复合语句内部,当定义它的函数体或复合语句执行时,C51 才为该变量分配内存空间, 结束时占用的内存空间释放。自动变量一般分配在内存的堆栈空间中。定义变量 时,如果省略存储种类,则该变量默认为自动(auto)变量。

②、extern: 使用extern 定义的变量称为外部变量。在一个函数体内,要使用一个已在该函数体外或别的程序中定义过的外部变量时,该变量在该函数体内要用 extern说明。外部变量被定义后分配固定的内存空间,在程序整个执行时间内 都有效,直到程序结束才释放。

③、static:
使用static定义的变量称为静态变量。它又分为内部静态变量和外部静态变量。在函数体内部定义的静态变量为内部静态变量,它在对应的函数体内有效,一直存在,但在函数体外不可见,这样不仅使变量在定义它的函数体外被保护,还可以实现当离开函数时值不被改变。外部静态变量上在函数外部定义的静态变量。它在程序中一直存在,但在定义的范围之外是不可见的。如在多文件或多模 块处理中,外部静态变量只在文件内部或模块内部有效。

④、register:
使用register 定义的变量称为寄存器变量。它定义的变量存放在CPU 内部 的寄存器中,处理速度快,但数目少。C51 编译器编译时能自动识别程序中使用 频率最高的变量,并自动将其作为寄存器变量,用户可以无需专门声明。

(4)、存储器类型
存储器类型是用于指明变量所处的单片机的存储器区域情况。存储器类型与存储种类完全不同。 C51编译器能识别的存储器类型有以下几种:

定义变量时也可以省“存储器类型”,省时C51 编译器将按编译模式默认存储器类型。

(5) 、特殊功能寄存器变量
51 系列单片机片内有许多特殊功能寄存器,通过这些特殊功能寄存器可以控制51 系列单片机的定时器、计数器、串口、I/O及其它功能部件,每一个特殊功能寄存器在片内RAM 中都对应于一个字节单元或两个字节单元。在C51 中,允许用户对这些特殊功能寄存器进行访问,访问时须通过sfr 或sfr16 类型说明符进行定义,定义时须指明它们所对应的片内RAM单元的地址。

sfr 用于对51 单片机中单字节的特殊功能寄存器进行定义,sfr16用于对双字节特殊功能寄存器进行定义。特殊功能寄存器名一般用大写字母表示。地址一般用直接地址形式。

(6) 、位变量
在C51 中,允许用户通过位类型符定义位变量。位类型符有两个:bit 和sbit。可以定义两种位变量。
在格式中可以加上各种修饰,但注意存储器类型只能是bdata、data、idata。只能是片内RAM 的可位寻址区,严格来说只能是bdata。

如位地址为位直接地址,其取值范围为0x00~0xff;
如位地址是可位寻址变量带位号或特殊功能寄存器名带位号,则在它前面须对可位寻址变量或特殊功能寄存器进行定义。字节地址与位号之间、特殊功能寄存器与位号之间一般用“^”作间隔。


在C51 中,为了用户操作方便,C51 编译器把51 单片机的常用的特殊功能寄存器和特殊位进行了定义,放在一个reg51.hreg52.h的头文件中,当用户要使用时,只须要在使用之前用一条预处理命令 #include #include 把这个头文件包含到程序最开始位置,然后就可使用殊功能寄存器名和特殊位名称。

2.2.3、运算符

2.2.3.1、赋值运算符

赋值运算符 = ,在C51 中,它的功能是将一个数据的值赋给一个变量, 如x=10。利用赋值运算符将一个变量与一个表达式连接起来的式子称为赋值表 达式,在赋值表达式的后面加一个分号“;”就构成了赋值语句,

在C51 中,允许在一个语句中同时给多个变量赋值,赋值顺序自右向左。

2.2.3.2、算术运算符

算术运算符这儿和咱们经常见到的那些是一致的,就不过多赘述啦~

常规的加减乘除我就不提啦,我这里写一下需要注意的点:
对于取余运算,则要求参加运算的两个数必须为整数,运算结果为它们的余数。例如:x=5%3,结果x 的值为2。

2.2.3.3 关系运算符

关系运算用于比较两个数的大小,用关系运算符将两个表达式连接起来形成的式子称为关系表达式。关系表达式通常用来作为判别条件构造分支或循环程序。

2.2.3.4、逻辑运算符

关系运算符用于反映两个表达式之间的大小关系,逻辑运算符则用于求条件式的逻辑值,用逻辑运算符将关系表达式或逻辑量连接起来的式子就是逻辑表达式。

逻辑与,格式: 条件式1 && 条件式2 当条件式1 与条件式2 都为真时结果为真(非0 值),否则为假(0 值)。

逻辑或,格式: 条件式1 || 条件式2 当条件式1 与条件式2 都为假时结果为假(0 值),否则为真(非0值)。

逻辑非,格式: !条件式 当条件式原来为真(非0 值),逻辑非后结果为假(0 值)。当条件式原来 为假(0值),逻辑非后结果为真(非0 值)。

例如:若a=8,b=3,c=0,则!a 为假,a && b 为真,b && c 为假。

2.2.3.5、位运算符

C51 语言能对运算对象按位进行操作。位运算是按位对变量进行运算,但并不改变参与运算的变量的值。如果要求按位改变 55 量的值,则要利用相应的赋值运算。C51中位运算符只能对整数进行操作,不能对浮点数进行操作。

大家接触比较少的应该是左移和右移运算符吧。简单来说了,这个两个运算符是对操作数的二进制形式操作的。

2.2.3.6、复合赋值运算符

C51中支持在赋值运算符 = 的前面加上其它运算符,组成复合赋值运算符。

复合赋值运算的一般格式如下:
变量 复合运算赋值符 表达式
它的处理过程:先把变量与后面的表达式进行某种运算,然后将运算的结果赋给前面的变量。是C51中 偷懒 简化程序的一种方法,大多数二目运算都可以用复合赋值运算符简化表示。

2.2.3.7、逗号运算符

在C51中,逗号“,”是一个特殊的运算符,可以用它将两个或两个以 上的表达式连接起来,称为逗号表达式。

程序执行时对逗号表达式的处理:按从左至右的顺序依次计算出各个表达式的值,而整个逗号表达式的值是最右边的表达式(表达式n)的值。
例如: x=(a=3,6*3)结果x 的值为18。

2.2.3.8、条件运算符

条件运算符 (逻辑表达式)?(表达式1):(表达式2)是C51 语言中唯一的一个三目运算符,它要求有三个运算对象,用它可以将三个表达式连接在一起构成一个条件表达式。

其功能是先计算逻辑表达式的值,当逻辑表达式的值为真(非0 值)时,将计算的表达式1 的值作为整个条件表达式的值;当逻辑表达式的值为假(0 值)时,将计算的表达式2 的值作为整个条件表达式的值。

例如:
maxv=(a>b)” />
指针运算符 * 放在指针变量前面,通过它实现访问以指针变量的内容为地址所指向的存储单元。
例如:指针变量p 中的地址为2000H,则*p 所访问的是地址为2000H 的存储单元,x =* p ,实现把地址为2000H 的存储单元的内容送给变量x。

取地址运算符 & 放在变量的前面,通过它取得变量的地址,变量的地址通常送给指针变量。
例如:设变量x 的内容为12H,地址为2000H,则 &x 的值为2000H,如有一指针变量p,则通常用 p=& x,实现将x 变量的地址送给指针变量p,指针变量p 指向变量x,以后可以通过*p 访问变量x。

2.2.4、表达式及复合语句

2.2.4.1、表达式语句


可以一行放一个表达式形成表达式语句,也可以一行放多个表达式形成表达式语句,这时每个表达式后面都必须带 ; 号,另外,还可以仅由—个分号占一行形成一个表达式语句,这种语句称为空语句。

2.2.4.2、复合语句

复合语句是由若干条语句组合而成的一种语句,在C51 中,用一个大括号{ }将若干条语句括在一起就形成了一个复合语句,复合语句最后不需要以分号“;”结束,但它内部的各条语句仍需以分号结束。

复合语句在执行时,其中的各条单语句按顺序依次执行,整个复合语句在语法上等价于一条单语句,因此在C51 中可以将复合语句视为一条单语句。

通常复合语句出现在函数中,实际上,函数的执行部分(即函数体)就是一个复合语句;复合语句中的单语句一般是可执行语句,此外还可以是变量的定义语句(说明变量的数据类型)。在复合语句内部语句所定义的变量,称为该复合语句中的局部变量,它仅在当前这个复合语句中有效。利用复合语句将多条单语句组合在—起,以及在复合语句中进行局部变量定义是C51 的一个重要特征。

2.2.5、基本结构和相关语句

2.2.5.1、顺序结构

顺序结构是最基本、最简单的结构,在这种结构中,程序由低地址到高地址依次执行

2.2.5.2、选择结构

选择结构可使程序根据不同的情况,选择执行不同的分支,在选择结构中,程序先都对一个条件进行判断。当条件成立,即条件语句为“真”时,执行一个分支,当条件不成立时,即条件语句为“假”时,执行另一个分支。
在C51 中,实现选择结构的语句为 if - else if - else if 语句。另外在C51中还支持多分支结构,多分支结构既可以通过if 和 else if 语句嵌套实现,可用swith/case 语句实现。

2.2.5.3、循环结构

在程序处理过程中,有时需要某一段程序重复执行多次,这时就需要循环结 构来实现,循环结构就是能够使程序段重复执行的结构。循环结构又分为两种:
当(while)型循环结构和直到(do…while)型循环结构。
①当型循环结构
当型循环结构如图:当条件P 成立(为“真”)时,重复执行语句A,当条件不成立(为“假”)时才停止重复,执行后面的程序。

②直到型循环结构
直到型循环结构,先执行语句A,再判断条件P,当条件成立(为“真”)时,再重复执行语句A,直到条件不成立(为“假”)时才停止重复,执行后面的程序
构成循环结构的语句主要有:while、do – while、for、goto。

2.2.5.4、break 和 continue 以及 return 语句

(1)、使用break 语句还可以从循环体中跳出循环,提前结束循环而接着执行循环结构下面的语句。它不能用在除了循环语句和switch 语句之外的任何其它语句中。

(2)、continue 语句用在循环结构中,用于结束本次循环,跳过循环体中continue下面尚未执行的语句,直接进行下一次是否执行循环的判定

(3)、return 语句一般放在函数的最后位置,用于终止函数的执行,并控制程序返回调用该函数时所处的位置。返回时还可以通过return语句带回返回值。return 语句格式有两种: ① return; ② return (表达式);
如果return语句后面带有表达式,则要计算表达式的值,并将表达式的值作为函数的返回值。若不带表达式,则函数返回时将返回一个不确定的值。通常我们用return语句把调用函数取得的值返回给主调用函数。

2.2.6、函数

2.2.6.1、函数的定义


格式说明:
1.函数类型
函数类型说明了函数返回值的类型。
2.函数名
函数名是用户为自定义函数取的名字以便调用函数时使用。
3.形式参数表
形式参数表用于列录在主调函数与被调用函数之间进行数据传递的形式参数。

区别在这儿:
4.reentrant 修饰符
这个修饰符用于把函数定义为可重入函数。所谓可重入函数就是允许被递归调用的函数。函数的递归调用是指当一个函数正被调用尚未返回时,又直接或间接调用函数本身。一般的函数不能做到这样,只有重入函数才允许递归调用。——(感觉不如c和cpp方便,一般也应该用不到,递归效率低,开发时候用不划算,权当了解吧)
关于重入函数,注意以下几点:
(1)用reentrant 修饰的重入函数被调用时,实参表内不允许使用bit 类型的参数。函数体内也不允许存在任何关于位变量的操作,更不能返回bit 类型的值。
2)编译时,系统为重入函数在内部或外部存储器中建立一个模拟堆栈区, 称为重入栈。重入函数的局部变量及参数被放在重入栈中,使重入函数可以实现递归调用。
3)在参数的传递上,实际参数可以传递给间接调用的重入函数。无重入属性的间接调用函数不能包含调用参数,但是可以使用定义的全局变量来进行参 数传递。
5、interrupt m 修饰符
interrupt m 是C51 函数中非常重要的一个修饰符,这是因为中断函数必须 通过它进行修饰。在C51 程序设计中,当函数定义时用了interrupt m修饰符, 系统编译时把对应函数转化为中断函数,自动加上程序头段和尾段,并按51 系 统中断的处理方式自动把它安排在程序存储器中的相应位置。
在该修饰符中,m 的取值为0~31,对应的中断情况如下:
0——外部中断0
1——定时/计数器T0
2——外部中断1
3——定时/计数器T1
4——串行口中断
5——定时/计数器T2
其它值预留。

⛅2.2.6.2、自定义函数的声明

在C51 中,函数原型一般形式如下:
[extern] 函数类型函数名(形式参数表);
函数的声明是把函数的名字、函数类型以及形参的类型、个数和顺序通知编译系统,以便调用函数时系统进行对照检查
函数的声明后面要加分号。如果声明的函数在文件内部,则声明时不用extern,如果声明的函数不在文件内部,而在另一个文件中,声明时须带extern,指明使用的函数在另一个文 件中。

2.2.7、构造数据类型

⛄2.2.7.1、数组

① 常规数组
需要注意的是,C51 语言中数组的下标是从0 开始的,因此上面:> 第一句定义 的5个元素分别是:x[0]、x[1]、x[2]、x[3]、x[4]。
第二句定义的3个元素分别是:y[0]、y[1]、y[2]。赋值情况为:y[0]=1;y[1]=2;y[2]=3。

C51 规定在引用数组时,只能逐个引用数组中的各个元素,而不能一次引用 整个数组。但如果是字符数组则可以一次引用整个数组

②字符数组
字符数组的定义与一般数组相同,只是在定义时把数据类型定义为char 型在C51中,字符数组用于存放一组字符或字符串,字符串以“\0”作为 结束符,只存放一般字符的字符数组的赋值与使用和一般的数组完全相同。对于存放字符串的字符数组。既可以对字符数组的元素逐个进行访问,也可以对整个 数组按字符串的方式进行处理。

总结

一、电平特性知道什么是高低电平,什么是TTL,什么是CMOS即可。因为倘若对它俩没有浅浅的印象了,首次开发的时候听老师说它们可能心中有有点小惊慌。

二、C51大致和C语言大多数是差不多的,我总结的内容可以也当做系统的复习和知识清单。
C51和C语言不同的地方我也用显眼的颜色备注出来了。直接拿捏就好,注意typedef叭,我看到很多项目源代码中的变量类型都是被重命名过的。

三、困惑解答
倘若在学习的路上担心自己一个人努力容易懈怠,或者担心自己get不到谷歌百度中的解答,小伙伴们可以加入这两个社区喔,它们都是获得了官方首页推荐滴~,社区内学习氛围良好,也有自己专属的问题解题Q群或者wx群呀,相互帮助,一起进步
高校算法学习社区
AI技术社