单片机汇编语言程序编程规范_第1页
单片机汇编语言程序编程规范_第2页
单片机汇编语言程序编程规范_第3页
单片机汇编语言程序编程规范_第4页
单片机汇编语言程序编程规范_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、精品文档你我共享腹有诗书气自华如果不统一编程规范, 最终写出的增加维护阶段的工作量, 同时不规引言软件设计更多地是一种工程,而不是一种个人艺术。 程序,其可读性将较差,这不仅给代码的理解带来障碍, 范的代码隐含错误的可能性也比较大。分析表明,编码阶段产生的错误当中,语法错误大概占20%左右,而由于未严格检查软件逻辑导致的错误、函数(模块)之间接口错误及由于代码可理解度低导致优化维护阶段对代 码的错误修改引起的错误则占了一半以上。可见,提高软件质量必须降低编码阶段的错误率。如何有效降低编码阶段的错误呢?这需要制定详细的软件编程规范,并培训每一位程序员,最终的结果可以把编码阶段的错误降至 10%左

2、右,同时也降低了程序的测试费用,效果相当显著。本文从代码的可维护性(可读性、可理解性、可修改性)、代码逻辑与效率、函数(模块)接口、可测试性四个方面阐述了软件编程规范,规范分成规则和建议两种,其中规则部分为强制执行项目,而建议部分则不作强制,可根据习惯取舍。1 排版规则1程序块使用缩进方式,函数和标号使用空格缩进,程序段混合使用TAB和空格缩进。缩进的目的是使程序结构清晰,便于阅读和理解。默认宽度应为8个空格,由于 Word中为4个空格,为示范清晰,此处用2个代替(下同)。例如:MOVR1,#00HMOVR2, #00HMOVPMR, #PMRNORMALMOVDPS, #FLAGDPTRMO

3、VDPTR, #ADDREEPROMreadlkloop:readlkpage:INCR1MOVX A, DPTRMOVSBUF, AJNBTI, $CLRTIINCDPTRCJNER1, #20H,read1kpageINCR2MOVR1, #00HCPLWDICJNER2, #20H, read1kloop;END OF EEPROM规则2在指令的操作数之间的,使用空格进行间隔, 采用这种松散方式编写代码的目的是使代码更加清晰。例如:CJNE R2, #20H, readlkloop;END OF EEPROM规则3一行最多写一条语句。规则4变量定义时,保持对齐。便于阅读和检查内存的使用情

4、况。例如:RegLEDLOSSEQU30H;VARIABLE:TESTLED=RegLEDLOSS.0RegLEDRAEQU31H;VARIABLERUNLED_FlagEQU32H;VARIABLE;256ms改变一次RUNLED状态RUNLED_DefEQU10H;STATIC;16*32ms=500ms 改变一次LED状态2注释注释的原则是有助于对程序的阅读理解,注释不宜太多也不能太少,太少不利于代码理解, 太多则会对阅读产生干扰,因此只在必要的地方才加注释,而且注释要准确、易懂、尽可能 简洁。注释量一般控制在30%到50%之间。规则1程序在必要的地方必须有注释,注释要准确、易懂、简洁。

5、例如如下注释意义不大:MOVDXCE1COUNTER, #00H;将 DXCE1COUNTER 赋值为 0而如下的注释则给出了额外有用的信息:JNZPcComm_Err;假如校验出错规则2注释应与其描述的代码相近,对代码的注释应放在其上方或右方(对单条语句的注释) 相邻位置,不可放在下面,如放于上方则需与其上面的代码用空行隔开。规则3头文件、源文件的头部,应进行注释。注释必须列出:文件名、作者、目的、功能、修改日规则4函数头部应进行注释,列出:函数的目的、功能、输入参数、输出参数、涉及到的通用变量 和寄存器、调用的其他函数和模块、 修改日志等。对一些复杂的函数, 在注释中最好提供典 型用法。规

6、则5对重要代码段的功能、意图进行注释,提供有用的、额外的信息。并在该代码段的结束处加一行注释表示该段代码结束。规则6对于所有的常量,变量,数据结构声明(包括数组、结构、类、枚举等 ),如果其命名不是充分自注释的,在声明时都必须加以注释,说明其含义。规则7维护代码时,要更新相应的注释,删除不再有用的注释。保持代码、注释的一致性,避免产 生误解。3命名规则1标识符缩写形成缩写的几种技术:1) 去掉所有的不在词头的元音字母。如screen写成scrn, primtive写成prmv。2) 使用每个单词的头一个或几个字母。如Channel Activation写成 ChanActiv , Releas

7、eIndication 写成 RelInd。3) 使用变量名中每个有典型意义的单词。如 Count of Failure写成FailCnt。4) 去掉无用的单词后缀ing, ed等。女口 Paging Request写成PagReq。5) 使用标准的或惯用的缩写形式(包括协议文件中出现的缩写形式)。女口 BSIC(BaseStation Identification Code)、MAP(Mobile Application Part)。关于缩写的准则:1) 缩写应该保持一致性。如Channel不要有时缩写成 Chan,有时缩写成 Ch。 Length有时缩写成Len,有时缩写成len。2) 在

8、源代码头部加入注解来说明协议相关的、非通用缩写。3) 标识符的长度不超过 12个字符。规则2变量命名约定: +主体;注释变量命名要考虑简单、直观、不易混淆。前缀是可选项,表示变量类型,由于汇编中变量多是单字节变量,所以单字节变量可以不加前缀,对于bit和双字节型变量,使用小写的b和d作为前缀表示。主体是必选项,可多个单词(或缩写)合在一起,每个单词首字母大写,其余部分小写。规则3常量的命名常量的命名规则:单词的字母全部大写,各单词之间用下划线隔开。规则4函数的命名单词首字母为大写,其余均为小写。函数名应以一个动词开头,即函数名应类似一个动词断 语或祈使句。例如:Test_Protect, Ch

9、eck_EEPROM, Init_Para4. 可维护性规则1函数和过程中关系较为紧密的代码尽可能相邻。规则2每个函数的源程序行数原则上应该少于200行。对于消息分流处理函数,完成的功能统一,但由于消息的种类多,可能超过200行的限制,不属于违反规定。规则3语句嵌套层次不得超过 5层。嵌套层次太多,增加了代码的复杂度及测试的难度,容易出错,增加代码维护的难度。规则4避免相同的代码段在多个地方出现。当某段代码需在不同的地方重复使用时,应根据代码段的规模大小使用函数调用或宏调用的方式代替。这样,对该代码段的修改就可在一处完成,增强代码的可维护性。规则5每个函数完成单一的功能,不设计多用途面面俱到的

10、函数。多功能集于一身的函数,很可能使函数的理解、测试、维护等变得困难。使函数功能明确化, 增加程序可读性,亦可方便维护、测试。规则6在函数的项目维护文档中,应该指出软件适用的硬件平台及版本。建议1使用专门的初始化函数对所有的公共变量进行初始化。5. 程序正确性、效率 规则1 严禁使用未经初始化的变量。特别是引用未经初始化的指针经常会导引用未经初始化的变量可能会产生不可预知的后果, 致系统崩溃,需特别注意。规则2防止内存操作越界。说明:内存操作越界是软件系统主要错误之一,后果往往非常严重。规则3注意变量的有效取值范围,防止表达式出现上溢或下溢。规则4防止易混淆的指令和操作数拼写错误。规则5避免函

11、数中不必要语句,防止程序中的垃圾代码,预留代码应以注释的方式出现。程序中的垃圾代码不仅占用额外的空间,而且还常常影响程序的功能与性能,很可能给程序的测试、维护等造成不必要的麻烦。规则6通过对系统数据结构的划分与组织的改进,以及对程序算法的优化来提高空间效率。这种方式是解决软件空间效率的根本办法。规则7循环体内工作量最小化。应仔细考虑循环体内的语句是否可以放在循环体之外,使循环体内工作量最小, 从而提高程序的时间效率。规则8在多重循环中,应将最忙的循环放在最内层。规则9避免循环体内含判断语句,将与循环变量无关的判断语句移到循环体外。目的是减少判断次数。循环体中的判断语句是否可以移到循环体外,要视

12、程序的具体情况而言,一般情况,与循环变量无关的判断语句可以移到循环体外,而有关的则不可以。规则10中断和恢复中断程序应该尽量短, 应该在中断中进行标记, 在主程序中处理。 但实时性很高的程序段例 外。中断时应该保存所有涉及到的通用变量和寄存器,如A, PSW, DPTR等。规则11堆栈设置堆栈对于程序非常重要,对于堆栈的设置要合理。 堆栈太小,在嵌套调用和很容易溢出,造成系统故障;堆栈太大,浪费RAM资源。为了节约堆栈资源,中断时要求不要保存太多资源,中断嵌套和程序嵌套层数不要太多,尽量不要超过5层。这就要求合理的划分功能模块。规则12看门狗看门狗电路用于在单片机死机时自动复位。单片机需要定时

13、向看门狗发送脉冲,俗称”喂狗”。喂狗不可太勤,这样看门狗没有起到作用;也不可太慢,这样容易造成单片机复位。正确的喂狗应该在主循环中进行, 最好是建立一个独立的系统监控进程。不可以在定时中断中喂狗,应为单片机有时可能会在主循环中死掉。6. 接口规则1去掉没有必要的公共变量,编程时应尽量少用公共变量。公共变量是增大模块间耦合的原因之一,故应减少没必要的公共变量以降低模块间的耦合度。应该构造仅有一个模块或函数可以修改、创建,而其余有关模块或函数只访问的公共变量,防止多个不同模块或函数都可以修改、创建同一公共变量的现象。规则2当向公共变量传递数据时,要防止越界现象发生。对公共变量赋值时,若有必要应进行

14、合法性检查,以提高代码的可靠性、稳定性。规则3尽量不设计多参数函数, 将不使用的参数从接口中去掉,降低接口复杂度,减少函数间接口的复杂度。规则4对所调用函数的返回码要仔细、全面地处理。防止把错误传递到后面的处理流程。如有意不检查其返回码,应明确指明。规则5检查接口函数所有输入参数的有效性。规则6检查函数的所有非参数输入,如外部数据、公共变量等。7. 代码可测性规则1模块编写应该有完善的测试方面的考虑。规则2源代码中应该设计了代码测试的内容。在编写代码之前,应预先设计好程序调试与测试的方法和手段,并设计好各种调测开关及相应测试代码。程序的调试与测试是软件生存周期中很重要的一个阶段,如何对软件进行

15、较全面、 高率的测试并尽可能地找出软件中的错误就成为很关键的问题。因此在编写源代码之前, 除了要有一套比较完善的测试计划外,还应设计出一系列代码测试手段, 为单元测试、集成测试及系统 联调提供方便。规则3在同一项目组或产品组内, 要有一套统一的为集成测试与系统联调准备的调测开关及相应函 数,并且要有详细的说明。本规则是针对项目组或产品组的。规则4在同一项目组或产品组内,调测打印出的信息串的格式要有统一的形式。信息串中至少要有所在模块名(或源文件名)及行号。统一的调测信息格式便于集成测试。规则5正式软件产品中应把调测代码去掉(即把有关的调测开关关掉)。规则6用调测开关来切换软件的 DEBUG版和

16、正式版,而不要同时存在正式版本和 DEBUG版本的 不同源文件,以减少维护的难度。规则7在软件系统中设置与取消有关测试手段,不能对软件实现的功能等产生影响。即有测试代码的软件和关掉测试代码的软件,在功能行为上应一致。规则8发现错误应该立即修改,并且若有必要记录下来。规则9开发人员应坚持对代码进行彻底的测试(单元测试),而不依靠他人或测试组来发现问题。规则10清理、整理或优化后的代码要经过审查及测试。规则11代码版本升级要经过严格测试。&代码编译规则1打开编译器的所有告警开关对程序进行编译。防止隐藏可能是错误的告警。规则2某些语句经编译后产生告警,但如果你认为它是正确的,那么应通过某种手段去掉告

17、警信息。 ps:从网上收集了一些相关内容,结合我自己的经验,欢迎拍砖,谢绝辱骂;ps2:有些可能不常用,因为大家写不到那么长的代码,就我自己写的最长的汇编代码也不 超过10K行;?硅谷芯微为莘莘学子提供全日制、在职嵌入式工程师技术培训,地处深圳市国家级高新科技产业园区内,配套设施齐全,实力有保障,欢迎来电咨询!?嵌入式工程师就业年薪保底 5万,企业紧缺人才,行业需求巨大!?硅谷芯微与学员签订培训合同,充分保障教学质量!?硅谷芯微外非深圳学员提供住宿、全日制自习室、全日制工程师指导的贴心服务!?大专以上学历通过入学咨询皆可报名!?开设课程:单片机、嵌入式、ARM、Linux、Android、ip

18、hone、PCB设计?联系方式0755-26733903咨询 QQ : 851022781、54068518? 官方网站:www.threeway.cc出师表两汉:诸葛亮先帝创业未半而中道崩殂,今天下三分,益州疲弊,此诚危急存亡之秋也。然侍卫之臣不懈于内,忠志之士忘身于外者,盖追先帝之殊遇,欲报之于陛下也。诚宜开张圣听,以光 先帝遗德,恢弘志士之气,不宜妄自菲薄,引喻失义,以塞忠谏之路也。宫中府中,俱为一体;陟罚臧否,不宜异同。若有作奸犯科及为忠善者,宜付有司论其 刑赏,以昭陛下平明之理;不宜偏私,使内外异法也。侍中、侍郎郭攸之、费祎、董允等,此皆良实,志虑忠纯,是以先帝简拔以遗陛下:愚 以为宫中之事,事无大小,悉以咨之,然后施行,必能裨补阙漏,有所广益。将军向宠,性行淑均,晓畅军事,试用于昔日,先帝称之曰能”是以众议举宠为督:愚以为营中之事,悉以咨之,必能使行阵和睦,优劣得所。亲贤臣,远小人,此先汉所以兴隆也; 亲小人,远贤臣,此后汉所以倾颓也。 先帝在时, 每与臣论此事,未尝不叹息痛恨于桓、 灵也。侍中、尚书、长史、参军,此悉贞良死节之臣, 愿陛下亲之、信之,则汉室之隆,可计日而待也 .FT臣本布衣,躬耕于南阳,苟全性命于乱世,不求闻达于诸侯。先帝不以臣卑鄙,猥自枉 屈,三

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论