1.C语言和汇编语言在开发单片机时各有哪些优缺点?答:汇编语言是一种用文字助记符来表示机器指令的符号语言,是最接近机器码的一种语言。其主要优点是占用资源少、程序执行效率高。但是不同的CPU,其汇编语言可能有所差异,所以不易移植。C语言是一种结构化的高级语言。其优点是可读性好,移植容易,是普遍使用的一种计算机语言。缺点是占用资源较多,执行效率没有汇编高。对于目前普遍使用的RISC架构的8bitMCU来说,其内部ROM、RAM、STACK等资源都有限,如果使用C语言编写,一条C语言指令编译后,会变成很多条机器码,很容易出现ROM空间不够、堆栈溢出等问题。而且一些单片机厂家也不一定能提供C编译器。而汇编语言,一条指令就对应一个机器码,每一步执行什幺动作都很清楚,并且程序大小和堆栈调用情况都容易控制,调试起来也比较方便。所以在单片机开发中,我们还是建议采用汇编语言比较好。如果对单片机C语言有兴趣,HOLTEK的单片机就有提供C编译器,可以到HOLTEK的网站(www.holtek.com.cn)免费下载使用。
上传时间: 2013-10-24
上传用户:qb1993225
本文介绍了一种高精度、宽范围的测时设备的设计技术。运用82C54的工作方式2作高精度时间测试,每片82C54的三个计数器前后级连,组成48位的计数器。选用AT89S52单片机作为MCU进行管理,应用总线方式扩展多片82C54,实现了高精度、宽范围的时间测量。采用4*4行列式键盘和128*64汉显LCD实现人机接口,并通过RS232C接口同计算机进行通信,方便了数据的存储和管理。
上传时间: 2013-11-13
上传用户:qq521
摘要:论述了选择时钟芯片DSl302制作电子时钟日历系统的难点问题;分析了一款选择AT89C51作为主控芯片的电子时钟硬件电路的工作原理,以及设计硬件电路时的注意事项;给出了主程序的流程图及几个主要功能子程序的设计思路;分析了DSl302时钟芯片的使用方法和注意事项,并给出了相应的解决方案。关键词:DSl302;AT89C51;电子时钟
上传时间: 2013-12-11
上传用户:18888888888
前面我们介绍了C语言的基本数据类型,但是在实际设计一个较复杂程序时,仅有这些基本类型的数据是不够的,有时需要将一批各种类型的数据放在一起使用,从而引入了所谓构造类型的数据.倒如前面介绍的数组就是一种构造类型的数据,一个数组实际上是将一批相同类型的数据顺序存放。这里我们还要介绍C语言中另一粪更为常用的构造类型数据:结构体、共用体夏枚举。
上传时间: 2013-11-12
上传用户:风为裳的风
利用分时操作系统中的分时调度思想可以使一个多终端的系统快速响应各终端的要求。本文首先介绍分时操作系统中的分时调度思想, 然后以程控交换机的控制系统为例, 在简介控制系统功能的基础上对用户的实时性要求进行分析, 论证了分时调度思想的可行性, 并利用该思想进行软件流程设计, 用A TM EL 89S51 替代原PC 机完成控制, 实现程控交换机的各种功能。
上传时间: 2013-11-20
上传用户:shirleyYim
PIC特殊指令助记符
上传时间: 2014-12-27
上传用户:天空说我在
摘要:AT89C2051是美国ATMEL公司生产的低电压、高性能CMOS8位单片机,采用高密度、非易失性存储技术生产,兼容标准MCS-51指令系统,适合许多高性价比的应用场合。文中采用AT89C2051芯片为北京某汽车公司设计了一个客车倒车监视系统,并介绍了相应的硬件设计和软件编程。只要挂上倒挡,系统便自动监视车后从0.35m至5.0m的视频图像,在客车进站中门打开时,系统会自动监视中门附近车内信息。该系统已投产使用,性能稳定,反应良好。关键词:AT89C2051;单片机;MCS一51;汽车电子
上传时间: 2013-10-25
上传用户:dianxin61
摘要:本文详细叙述了基于FPGA及单片机K实现时码终端系统的设计方法,该系统可用于对国际通用时间格式码IRIG码(简称B码)的解调,以及产生各种采样、同步频率信号,也可作为其它系统的时基和采样、同步信号的基准。关键词:单片机;IRIG-B格式码;FPGA;解调;控制;接口
上传时间: 2013-12-16
上传用户:CSUSheep
HT47R20A-1时基(Time Base)使用介绍 HT47 系列单片机的时基可提供一个周期性超时时间周期以产生规则性的内部中断。时基的时钟来源可由掩膜选择设定为WDT 时钟、RTC 时钟或指令时钟(系统时钟/4);其超时时间范围可由掩膜选择设定为“时钟来源”/212~“时钟来源”/215。如果时基发生超时现象,则其对应的中断请求标志(TBF)会被置位,如果中断允许,则产生一个中断服务到08H 的地址。
上传时间: 2013-11-15
上传用户:13925096126
SDRAM的原理和时序 SDRAM内存模组与基本结构 我们平时看到的SDRAM都是以模组形式出现,为什么要做成这种形式呢?这首先要接触到两个概念:物理Bank与芯片位宽。1、 物理Bank 传统内存系统为了保证CPU的正常工作,必须一次传输完CPU在一个传输周期内所需要的数据。而CPU在一个传输周期能接受的数 据容量就是CPU数据总线的位宽,单位是bit(位)。当时控制内存与CPU之间数据交换的北桥芯片也因此将内存总线的数据位宽 等同于CPU数据总线的位宽,而这个位宽就称之为物理Bank(Physical Bank,下文简称P-Bank)的位宽。所以,那时的内存必须要组织成P-Bank来与CPU打交道。资格稍老的玩家应该还记 得Pentium刚上市时,需要两条72pin的SIMM才能启动,因为一条72pin -SIMM只能提供32bit的位宽,不能满足Pentium的64bit数据总线的需要。直到168pin-SDRAM DIMM上市后,才可以使用一条内存开机。不过要强调一点,P-Bank是SDRAM及以前传统内存家族的特有概念,RDRAM中将以通道(Channel)取代,而对 于像Intel E7500那样的并发式多通道DDR系统,传统的P-Bank概念也不适用。2、 芯片位宽 上文已经讲到SDRAM内存系统必须要组成一个P-Bank的位宽,才能使CPU正常工作,那么这个P-Bank位宽怎么得到呢 ?这就涉及到了内存芯片的结构。 每个内存芯片也有自己的位宽,即每个传输周期能提供的数据量。理论上,完全可以做出一个位宽为64bit的芯片来满足P-Ban k的需要,但这对技术的要求很高,在成本和实用性方面也都处于劣势。所以芯片的位宽一般都较小。台式机市场所用的SDRAM芯片 位宽最高也就是16bit,常见的则是8bit。这样,为了组成P-Bank所需的位宽,就需要多颗芯片并联工作。对于16bi t芯片,需要4颗(4×16bit=64bit)。对于8bit芯片,则就需要8颗了。以上就是芯片位宽、芯片数量与P-Bank的关系。P-Bank其实就是一组内存芯片的集合,这个集合的容量不限,但这个集合的 总位宽必须与CPU数据位宽相符。随着计算机应用的发展,
上传时间: 2013-11-04
上传用户:zhuimenghuadie