MCU或DSP变量及函数命名——云备忘

1 变量

       变量名的完整结构:<数据类型缩写>_<变量描述>_<数据结构>

       说明:

(1) 变量名的下划线最好不超过2个;

(2) <数据类型缩写>和<变量描述>是必须的,<数据结构>部分不是必须的; 

(3) 规则适用于形参和实参。

1.1 变量数据类型

TABLE I MCU和DSP常用的数据类型
序号数据类型数据长度(bit)变量缩写
1unsigned   char8u8,uc8,ui8
2signed   char8sc8,c8,i8
3signed short int16ssi16,si16,s16,i16
4unsigned short int16usi16,ui16,us16,u16
5signed int32si32,i32
6unsigned int32ui32,u32
7float32f32

       说明:

(1) 为了尽量--,建议用红色缩写;

(2) 必须标明数据长度,数字部分不能省;

(3) 能相互区别;

(4) 能满足上面3个条件其它缩写也OK。

1.2 变量描述

要求:

(1) 说清楚干嘛的,临时变量除外,但临时变量建议用一个或几个固定的字母或者词组;

举例:标志 Flag,计数值 Counter

典型的临时变量 i,j,k;或者temp1,temp2,temp3;或者aka1,aka2,aka3等

(2) 不要太长,按习惯对单词进行缩写或者带注释的情况下对固定单词进行固定缩写;

举例:不管什么灯 Led,直流源 Dc,交流源 Ac,脱氧核糖核酸 Dna,不明飞行物Ufo

电流 ‘Cur  // 电流’   等

(3) 不要加额外下划线,按首字母大写的规则划分多单词变量。

举例:红灯 LedRed,蓝灯 LedBlue,直流输入电流 DcInputCur, 夜王终结者 NightKingSlayer

1.3 数据结构

主要指的是指针,数组,结构体,当然指针不建议使用。

TABLE II MCU或DSP常用数据结构说明
序号数据结构数据结构类型
1指针Ptr
2数组Arry
3结构体Stru

说明:变量说明的缩写不唯一,但同一个工程文件统一就行。

1.4 形参和实参

形参和实参同名怎么办?

(1) 扩大形参的变量描述范围

举例:实参是 LedRed,形参 Led;实参是 Led,形参 TotalLed;实参 Hand,形参 Body

(2) 去掉下划线

举例:实参<数据类型缩写>_<变量描述>_<数据结构>,形参<数据类型缩写>_<变量描述><数据结构>;实参<数据类型缩写>_<变量描述>,形参<数据类型缩写><变量描述>

综上,如果需要一个无符的16位的结构体记录16个红灯的亮灭状态(只是为了说明怎么定变量名),这个变量可以命名为 u16_LedRed_Stru。

2 函数

       函数名的完整结构:<数据类型 或 功能类型>_<函数描述>

       说明:

(1) 函数名的下划线最好不超过2个;

(2) <函数描述>是必须的,<功能类型或数据类型>二者必有其一且可以兼而有之; 

(3) 规则适用于主函数外的所有非底层函数。

2.1 函数描述

       参考1.2。

2.2 功能类型

        主要说明函数执行的什么类型的任务。

TABLE III 常用的函数功能说明
序号函数功能功能类型
1数据处理Dat
2特定功能函数App
3逻辑控制Log
4控制算法实现Alg

2.3 数据类型

       常用的数据类型参考1.1,函数数据类型主要指函数返回值数据类型和形参的数据类型,当有返回值或者函数有形参的时候需要注明数据类型,且数据类型必须是首位,数据类型标注参考Table I 。

        Dat和Alg不一定有形参或者返回值,但是根据处理数据类型标注数据类型,对于出现需要处理多种数据类型的有浮点标注浮点,没有浮点与数据长度最长的对齐。如果是App或者Log函数可以不对涉及的处理数据类型进行标注。

        如果形参包含多种数据类型有浮点标注浮点,没有浮点与数据长度最长的对齐。

综上,如果需要对一个采样数据进行浮点标幺化处理,该函数就可以命名为f32_Dat_SampleNormalization()。

3 宏定义

       严格来说不是变量,但是也需要命名。

       要求是所有字母全大写,允许多下滑线,命名结构包含信息:

(1) 什么功能或者设备;

举例:这个宏用在什么功能,电源SOURCE,电机 MOTOR或者其他

(2) 描述;

举例:是某个数据的阈值THRESHOLD或者某个计算的固定系数COEFFICIENT

(3) 直接对象说明。

举例:是周期频率 FREQ、温度 TEMPER、转速 RSPEED、电压 VOL或者电流 CUR

综上,电机转速阈值可命名为MOTOR_THRESHOLD_RSPEED。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值