📄 单片机汇编程序编码规范.htm
字号:
<TD><STRONG><FONT color=#ff0000>酷贴推荐 <FONT color=#ff0000>[</FONT><A href="http://blog.21ic.org/more.asp?name=cxjr&id=7437" target=_blank><U><FONT color=#ff0000>更多…… </FONT></U></A><FONT color=#ff0000>]</FONT></FONT></STRONG></TD></TR>
<TR bgColor=#ffffff>
<TD>
<P align=left>
<TABLE borderColor=#cccccc cellSpacing=2 cellPadding=3 width="100%" bgColor=#ffffff border=1>
<TBODY>
<TR>
<TD>
<P align=center> [<A href="http://blog.21ic.com/more.asp?name=cxjr&id=16591"><U><FONT style="BACKGROUND-COLOR: #ffff00" color=#ff0000>岁月如歌——记匠人的百宝箱博客开通一周年</FONT></U></A>] [<A href="http://blog.21ic.com/more.asp?name=cxjr&id=17379"><U><FONT color=#0000ff>事件驅動觀念</FONT></U></A>] [<A href="http://blog.21ic.com/more.asp?name=cxjr&id=17377"><U><FONT color=#0000ff>单片机程序设计中运用事件驱动机制</FONT></U></A>]</P></TD>
<TR>
<TD>
<P align=center>[<A href="http://blog.21ic.com/more.asp?name=cxjr&id=18941"><U><FONT color=#0000ff>计算机族必喝的健康饮料</FONT></U></A>] [<A href="http://blog.21ic.com/more.asp?name=cxjr&id=18714"><U><FONT color=#0000ff>男人·女人·电脑</FONT></U></A>] [<A href="http://blog.21ic.com/more.asp?name=cxjr&id=18713"><U><FONT color=#0000ff>学编程的人不能不看的好文章</FONT></U></A>] [<A href="http://blog.21ic.com/more.asp?name=cxjr&id=18742"><U><FONT color=#0000ff>PIC机与MCS-51的区别</FONT></U></A>]</P></TD>
<TR>
<TD>
<P align=center>[<A href="http://blog.21ic.com/more.asp?name=cxjr&id=19794"><U><FONT color=#0000ff>一种软件去除键抖动的方法</FONT></U></A>] [<A href="http://blog.21ic.com/more.asp?name=cxjr&id=19752"><U><FONT color=#0000ff>司马光,你干嘛砸缸?</FONT></U></A>] [<A href="http://blog.21ic.com/more.asp?name=cxjr&id=19748"><U><FONT color=#0000ff>编码规范</FONT></U></A>] </P></TD>
<TR>
<TD>
<P align=center><FONT color=#ff0000>调查:[</FONT><A href="http://21icbbs.com/club/vote/showvote.asp?id=98" target=_blank><U><FONT color=#ff0000>您认为《匠人的百宝箱》如何?</FONT></U></A><FONT color=#ff0000>] [</FONT><A href="http://21icbbs.com/club/vote/showvote.asp?id=129" target=_blank><U><FONT color=#ff0000>您最喜欢《匠人的百宝箱》中哪个栏目?</FONT></U></A><FONT color=#ff0000>] [</FONT><A href="http://blog.21ic.com/more.asp?name=cxjr&id=18993"><U><FONT color=#ff0000>请网友来评选最佳队员专栏</FONT></U></A><FONT color=#ff0000>]</FONT> </P></TD></TR></TBODY></TABLE></P></TD></TR></TBODY></TABLE></P>
<P align=left>
<TABLE style="TABLE-LAYOUT: fixed; WORD-BREAK: break-all" cellSpacing=1 cellPadding=3 width="100%" bgColor=#cccccc border=0>
<TBODY>
<TR bgColor=#f8f8f8>
<TD>
<P align=left><FONT color=#ff0000 size=4><STRONG><img src=images/face/4.gif ><a href=blog.asp?name=cxjr&subjectid=66>[编程技巧]<a href=more.asp?name=cxjr&id=2582>单片机汇编程序编码规范</a></STRONG></FONT><BR>程序匠人 2005-8-21 14:00:00 <a href=more.asp?name=cxjr&id=2582>阅读全文(1575)</a> | <a href=more.asp?name=cxjr&id=2582#comment>回复(0)</a> | <a href=showtb.asp?id=2582 target=_blank>引用(0)</a><BR><FONT face=宋体 size=4><STRONG>[</STRONG></FONT><A href="http://blog.21ic.org/more.asp?name=cxjr&id=6250" target=_blank><FONT face=宋体 color=#ff0000 size=4><STRONG>广告8号位</STRONG></FONT></A><FONT face=宋体 size=4><STRONG>] [</STRONG></FONT><A href="http://blog.21ic.org/more.asp?name=cxjr&id=7705"><U><FONT style="BACKGROUND-COLOR: #000000" face=宋体 color=#ffffff size=4><STRONG>免责声明</STRONG></FONT></U></A><FONT face=宋体 size=4><STRONG>] [</STRONG><A href="http://blog.21ic.com/more.asp?name=cxjr&id=18993"><U><FONT style="BACKGROUND-COLOR: #ffff00" color=#ff0000 size=3><STRONG>请网友来评选最佳队员专栏!</STRONG></FONT></U></A><STRONG>]</STRONG></FONT></P></TD></TR>
<TR bgColor=#ffffff>
<TD height=0>
<DIV align=left><P><BR> 主题:【原创】单片机汇编程序编码规范——欢迎拍砖,谢绝辱骂返回主题列表</P>
<P> 刷新 社员投票PAGE 1 / 1 共17篇 返回主题列表 返回前个操作首页 前页 后页 尾页 已存档老贴 </P>
<P> 后学 发表于 2005-7-13 18:48 侃单片机 ←返回版面 </P>
<P> 【原创】单片机汇编程序编码规范——欢迎拍砖,谢绝辱骂</P>
<P> 单片机汇编程序编码规范<BR> Jamie.Y</P>
<P> 引言<BR> <BR> 软件设计更多地是一种工程,而不是一种个人艺术。如果不统一编程规范,最终写出的程序,其可读性将较差,这不仅给代码的理解带来障碍,增加维护阶段的工作量,同时不规范的代码隐含错误的可能性也比较大。<BR> 分析表明,编码阶段产生的错误当中,语法错误大概占20%左右,而由于未严格检查软件逻辑导致的错误、函数(模块)之间接口错误及由于代码可理解度低导致优化维护阶段对代码的错误修改引起的错误则占了一半以上。<BR> 可见,提高软件质量必须降低编码阶段的错误率。如何有效降低编码阶段的错误呢?这需要制定详细的软件编程规范,并培训每一位程序员,最终的结果可以把编码阶段的错误降至10%左右,同时也降低了程序的测试费用,效果相当显著。<BR> 本文从代码的可维护性(可读性、可理解性、可修改性)、代码逻辑与效率、函数(模块)接口、可测试性四个方面阐述了软件编程规范,规范分成规则和建议两种,其中规则部分为强制执行项目,而建议部分则不作强制,可根据习惯取舍。</P>
<P> 1.排版<BR> 规则1<BR> 程序块使用缩进方式,函数和标号使用空格缩进,程序段混合使用TAB和空格缩进。缩进的目的是使程序结构清晰,便于阅读和理解。<BR> <TAB>默认宽度应为8个空格,由于Word中<TAB>为4个空格,为示范清晰,此处用2个<TAB>代替(下同)。<BR> 例如:<BR> MOV R1, #00H<BR> MOV R2, #00H<BR> MOV PMR, #PMRNORMAL<BR> MOV DPS, #FLAGDPTR<BR> MOV DPTR, #ADDREEPROM<BR> read1kloop:<BR> read1kpage:<BR> INC R1<BR> MOVX A, @DPTR<BR> MOV SBUF, A<BR> JNB TI, $<BR> CLR TI <BR> INC DPTR<BR> CJNE R1, #20H, read1kpage<BR> INC R2<BR> MOV R1, #00H<BR> CPL WDI<BR> CJNE R2, #20H, read1kloop ;END OF EEPROM</P>
<P> 规则2 <BR> 在指令的操作数之间的,使用空格进行间隔,采用这种松散方式编写代码的目的是使代码更加清晰。<BR> 例如:<BR> CJNE R2, #20H, read1kloop ;END OF EEPROM</P>
<P> 规则3 <BR> 一行最多写一条语句。</P>
<P> 规则4 <BR> 变量定义时,保持对齐。便于阅读和检查内存的使用情况。<BR> 例如:<BR> RegLEDLOSS EQU 30H ; VARIABLE ; <BR> TESTLED==RegLEDLOSS.0<BR> RegLEDRA EQU 31H ; VARIABLE<BR> RUNLED_Flag EQU 32H ; VARIABLE ; <BR> 256ms改变一次RUNLED状态<BR> RUNLED_Def EQU 10H ; STATIC ; <BR> 16*32ms=500ms改变一次LED状态</P>
<P><BR> 2.注释<BR> 注释的原则是有助于对程序的阅读理解,注释不宜太多也不能太少,太少不利于代码理解,太多则会对阅读产生干扰,因此只在必要的地方才加注释,而且注释要准确、易懂、尽可能简洁。注释量一般控制在30%到50%之间。</P>
<P> 规则1<BR> 程序在必要的地方必须有注释,注释要准确、易懂、简洁。<BR> 例如如下注释意义不大:<BR> MOV DXCE1COUNTER, #00H ; 将DXCE1COUNTER赋值为0<BR> 而如下的注释则给出了额外有用的信息:<BR> JNZ PcComm_Err ; 假如校验出错</P>
<P> 规则2 <BR> 注释应与其描述的代码相近,对代码的注释应放在其上方或右方(对单条语句的注释)相邻位置,不可放在下面,如放于上方则需与其上面的代码用空行隔开。</P>
<P> 规则3<BR> 头文件、源文件的头部,应进行注释。注释必须列出:文件名、作者、目的、功能、修改日志等。</P>
<P> 规则4<BR> 函数头部应进行注释,列出:函数的目的、功能、输入参数、输出参数、涉及到的通用变量和寄存器、调用的其他函数和模块、修改日志等。对一些复杂的函数,在注释中最好提供典型用法。</P>
<P> 规则5<BR> 对重要代码段的功能、意图进行注释,提供有用的、额外的信息。并在该代码段的结束处加一行注释表示该段代码结束。</P>
<P> 规则6<BR> 对于所有的常量,变量,数据结构声明(包括数组、结构、类、枚举等),如果其命名不是充分自注释的,在声明时都必须加以注释,说明其含义。</P>
<P> 规则 7<BR> 维护代码时,要更新相应的注释,删除不再有用的注释。保持代码、注释的一致性,避免产生误解。</P>
<P><BR> 3.命名<BR> 规则 1<BR> 标识符缩写<BR> 形成缩写的几种技术:<BR> 1) 去掉所有的不在词头的元音字母。如screen写成scrn, primtive写成prmv。<BR> 2) 使用每个单词的头一个或几个字母。如Channel Activation写成ChanActiv,Release <BR> Indication写成RelInd。<BR> 3) 使用变量名中每个有典型意义的单词。如Count of Failure写成FailCnt。<BR> 4) 去掉无用的单词后缀 ing, ed等。如Paging Request写成PagReq。<BR> 5) 使用标准的或惯用的缩写形式(包括协议文件中出现的缩写形式)。如BSIC(Base Station <BR> Identification Code)、MAP(Mobile Application Part)。<BR> 关于缩写的准则:<BR> 1) 缩写应该保持一致性。如Channel不要有时缩写成Chan,有时缩写成Ch。Length有时缩写成Len,有时缩写成len。<BR> 2) 在源代码头部加入注解来说明协议相关的、非通用缩写。<BR> 3) 标识符的长度不超过12个字符。</P>
<P> 规则2<BR> 变量命名约定:<前缀> + 主体 ; 注释<BR> 变量命名要考虑简单、直观、不易混淆。<BR> 前缀是可选项,表示变量类型,由于汇编中变量多是单字节变量,所以单字节变量可以不加前缀,对于bit和双字节型变量,使用小写的b和d作为前缀表示。<BR> 主体是必选项,可多个单词(或缩写)合在一起,每个单词首字母大写,其余部分小写。</P>
<P> 规则3<BR> 常量的命名<BR> 常量的命名规则:单词的字母全部大写,各单词之间用下划线隔开。</P>
<P> 规则4<BR> 函数的命名<BR> 单词首字母为大写,其余均为小写。函数名应以一个动词开头,即函数名应类似一个动词断语或祈使句。<BR> 例如:Test_Protect, Check_EEPROM, Init_Para</P>
<P><BR> 4.可维护性<BR> 规则1<BR> 函数和过程中关系较为紧密的代码尽可能相邻。</P>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -