【单片机期末】单片机系统设计

主要内容:系统状态机,系统时基,系统需求分析,系统构建,系统状态流图

一、题目要求

二、绘制系统状态流图

题目:根据上述描述绘制系统状态流图,注明状态转移条件及方向。

三、利用定时器产生时基

题目:由Timer1定时器中断产生1ms时基,在1ms时基基础上产生10ms,100ms,500ms和1s的时基。

1.编写Timer1的中断服务程序

(要仔细看清题目要求是用 Timer0 还是 Timer1 )

2.编写系统时基实现程序

四、定义系统的状态变量

系统状态字不同,代表系统处于不同的状态。不要轻易浪费资源。

题目:根据上述描述定义系统的状态变量,状态时间变了、各种状态变量、按键变量以及按键功能敞亮定义,例#define xx_State 0x01

1.系统状态变量声明

2.状态时间变量声明

3.系统状态常量定义

(实际考察对于宏定义的理解以及应用)

4.按键相关变量定义

5.按键常量定义

五、定义各个状态函数

题目:定义各个状态函数,例void Fun_xxState(void){}//xx状态函数,函数声明需完整,注释清楚,函数具体实现内容不需要编写,根据自己定义的函数编写系统状态机控制函数Fun_SysState

六、编写系统【空闲】状态函数

题目:编写完整的系统【空闲】状态函数,添加注释

七、编写系统【分编辑】状态函数

题目:编写完整的系统【分编辑】状态函数,添加注释

八、部分示例代码

1.主程序

2.系统状态机

3.系统上电程序

(系统状态每10ms调用一次 → 3s = 3 * 100)

4.系统关机程序

5.系统工作程序

按键宏定义

6.系统显示函数

7.系统暂停程序

这些函数中全都是对系统变量的操作,而系统的变量以什么样的形式去显示是在其他环节完成的,例如通过串行口发送出去。

8.串行口初始化

【注意】在proteus中做仿真时,需要将51单片机的时钟频率改为11.0596MHz才能跟计算机通信,否则计算出的波特率有误差,无法实现与计算机的通信。

相关推荐
XINVRY-FPGA1 小时前
XCVU9P-2FLGA2104E Xilinx AMD Virtex UltraScale+ FPGA
人工智能·嵌入式硬件·fpga开发·硬件工程·dsp开发·射频工程·fpga
10001hours3 小时前
(基于江协科技)51单片机入门:7.LED点阵屏
科技·嵌入式硬件·51单片机
10001hours4 小时前
(基于江协科技)51单片机入门:9.蜂鸣器
科技·嵌入式硬件·51单片机
transuperb5 小时前
51单片机红外遥控
单片机·嵌入式硬件
senator参议员6 小时前
【软件使用】Calibre部分提参
学习
鲸落落丶7 小时前
webpack学习
前端·学习·webpack
zhangrelay7 小时前
操作系统全解析:Windows、macOS与Linux的深度对比与选择指南(AI)
linux·笔记·学习
程序边界7 小时前
AI时代如何高效学习Python:从零基础到项目实战de封神之路(2025升级版)
人工智能·python·学习
灰太狼大王灬7 小时前
Node.js 本地服务部署、常驻及调用完整笔记
笔记·node.js
聪明的笨猪猪7 小时前
Java SE “面向对象”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试