日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > > strongerHuang
[導讀]關注、 星標公眾號,不錯過精彩內容 素材來源:micrium 編輯整理:strongerHuang 開發(fā)過項目的工程師都知道,一個好的項目,代碼基本都有統(tǒng)一的規(guī)范,否則代碼就會隨著版本迭代,變得越來越臃腫。 代碼規(guī)范應在項目早期建立,這些規(guī)范對于保持整個項目的一致

關注、 星標公眾,不錯過精彩內容

素材來源:micrium

編輯整理:strongerHuang


開發(fā)過項目的工程師都知道,一個好的項目,代碼基本都有統(tǒng)一的規(guī)范,否則代碼就會隨著版本迭代,變得越來越臃腫。


代碼規(guī)范應在項目早期建立,這些規(guī)范對于保持整個項目的一致性非常有必要,采用一致的規(guī)范可以提高效率并簡化項目維護。


采用一致的規(guī)范可以:

  • 可移植性

  • 一致性

  • 整潔

  • 維修方便

  • 容易理解

  • 簡單


下面來看看著名的μC/OS代碼的規(guī)范。

一、標頭
C源文件的標頭如下所示,公司名稱和地址可以在前幾行,后跟一個標題,用于描述文件的內容。其中包含版權聲明,以警告該軟件的專有性等。
/************************************************************************************************** Company Name* Address** (c) Copyright 19xx, Company Name, City, State* All Rights Reserved*** Filename :* Programmer(s):* Description :*************************************************************************************************//*$PAGE*/

二、包含文件
#include包含通常有兩種方式,在源文件中包含所需的頭文件,還有一種把所有頭文件都整理在一個文件,比如INCLUDES.H。這樣你就 不必記住哪個頭文件與哪個源文件一起使用,尤其是在添加新模塊時。唯一的不便是編譯每個文件需要更長的時間。
/************************************************************************************************** INCLUDE FILES*************************************************************************************************/#include "INCLUDES.H"/*$PAGE*/

三、命名標識符

符合ANSI C標準的C編譯器(到目前為止,大多數C編譯器都這樣做)最多允許32個字符作為標識符名稱。標識符是變量、結構/聯(lián)合成員、函數、宏、#defines等。


比如:大寫字符用于分隔標識符中的單詞,功能和下劃線字符(_)類似。

static INT16U KeyCharCnt; /* Number of keys pressed */static char KeyInBuf[100]; /* Storage buffer to hold chars */ char KeyInChar; /* Character typed */
/*$PAGE*/

μC/OS命名標識符:

  • 函數聲明中的形式參數應僅包含小寫字符。

  • 自動變量名稱應僅包含小寫字符。

  • 靜態(tài)變量和函數應使用文件/模塊名稱(或其一部分)作為前綴,并應使用大寫/小寫字符。

  • extern變量和函數應使用文件/模塊名稱(或其一部分)作為前綴,并應使用大寫/小寫字符。


四、縮略
代碼基本都會使用縮寫,縮寫不能中英文混合,通常是英文的縮寫,比如OS代表Operating System。

一些常用的縮寫需要統(tǒng)一規(guī)范,一些不常用的縮寫需要在代碼中注釋清除。

μC/OS代碼中使用的縮寫比較多,比如:
縮寫
原意
Addr Address
Blk Block
Chk Check
Clr Clear
Cnt Count
CPU Central Processing Unit
Ctr Counter
Ctx Context
Cur Current
Del Delete
Dly Delay
Err Error

五、注釋
//  /* */ 是兩種最常見注釋的方法,還有注釋的位置也很關鍵。通常在代碼所在行上一行,或者在代碼所在行(代碼后面)。

但也有奇葩把代碼注釋在代碼所在行的下一行(通常不建議這么操作)。

μC/OS使用 /**/ 而且都在代碼所在行(后面):
int atoi (char *s){ int n; /* Partial result of conversion */

n = 0; /* Initialize result */ while (*s >= '0' && *s <= '9' && *s) { /* For all valid characters and not end of string */ n = 10 * n + *s - '0'; /* Convert char to int and add to partial result */ s++; /* Position on next character to convert */ } return (n); /* Return the result of the converted string */}

六、#defines
頭文件(.H)和C源文件(.C)可能需要定義常量和宏,常量和宏始終使用大寫字母。
#define KEY_FF 0x0F#define KEY_CR 0x0D#define KEY_BUF_FULL() (KeyNRd > 0)

七、數據類型
C語言允許你使用typedef關鍵字創(chuàng)建新的數據類型,μC/OS使用大寫字符聲明所有數據類型,因此遵循用于常量和宏的相同規(guī)則,永遠不會混淆常量,宏和數據類型的問題。
typedef unsigned char BOOLEAN; /* Boolean */typedef unsigned char INT8U; /* 8 bit unsigned */typedef char INT8S; /* 8 bit signed */typedef unsigned int INT16U; /* 16 bit unsigned */typedef int INT16S; /* 16 bit signed */typedef unsigned long INT32U; /* 32 bit unsigned */typedef long INT32S; /* 32 bit signed */typedef float FP; /* Floating Point */

八、局部變量

一些源模塊要求使用局部變量,通過使用static關鍵字,變量可以按字母順序或功能順序列出。

static char KeyBuf[100];static INT16S KeyNRd;


九、縮進

縮進有使用空格和Tab兩種符號,規(guī)范通常只使用一種,不能空格和Tab兩種混合使用(現在很多編輯器都支持Tab替換成空格的功能)。


如果混合使用,在不同編輯器打開代碼,你就可能會看到一團糟。


μC/OS使用四個空格:

if (x < 0) z = 25;if (y > 2) { z = 10; x = 100; p++;}


十、結構體和聯(lián)合體

包含結構體和聯(lián)合體的格式、命名、注釋等這些都需要規(guī)范,μC/OS代碼使用的比較簡單,也是大眾化的定義:

typedef struct line { /* Structure that defines a LINE */ int LineStartX; /* 'X' & 'Y' starting coordinate */ int LineStartY;  int LineEndX; /* 'X' & 'Y' ending coordinate */ int LineEndY;  int LineColor; /* Color of line to draw */} LINE;typedef struct point { /* Structure that defines a POINT */ int PointPosX; /* 'X' & 'Y' coordinate of point */ int PointPosY; int PointColor; /* Color of point */} POINT;


本文就寫到這里,代碼規(guī)范建議參考一些大廠的規(guī)范手冊。當然,每家公司的代碼規(guī)范可能有所不同,只要寫代碼是時統(tǒng)一就行。


免責聲明: 本文素材來源網絡,版權歸原作者所有。如涉及作品版權問題,請與我聯(lián)系刪除。
推薦閱讀:
在多任務(RTOS)環(huán)境中使用看門狗的重要性
Windows Terminal 1.0 和 Linux 版有啥區(qū)別
從大端CPU遷移到小端CPU,及字節(jié)序的遷移技術

關注 微信公眾號『strongerHuang』,后臺回復“1024”查看更多內容,回復“加群”按規(guī)則加入技術交流群。


長按前往圖中包含的公眾號關注

免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀

深圳2026年3月19日 /美通社/ -- 2026年的招聘市場,正陷入一場奇特的"算法互博":求職者用AI美化簡歷以通過篩選,企業(yè)用AI深挖細節(jié)以識別真?zhèn)?。這場博弈的背后,是簡歷日益"豐滿...

關鍵字: AI 代碼 LAB 模型

美國舊金山和中國蘇州2026年2月8日 /美通社/ -- 信達生物制藥集團(香港聯(lián)交所股票代碼:01801),一家致力于研發(fā)、生產和銷售腫瘤、自身免疫、代謝、眼科等重大疾病領域創(chuàng)新藥物的生物制藥公司,宣布與禮來制藥達成戰(zhàn)...

關鍵字: COM 代碼 創(chuàng)始人 控制

香港2026年2月4日 /美通社/ -- 華欽科技集團(納斯達克代碼:CLPS,以下簡稱"華欽科技"或"集團")今日宣布其董事會已通過一項集團股份回購計劃的決議。該決議聲明,當集團股價低于每股2美元時,集團可在公開市場上...

關鍵字: PS BSP 代碼 納斯達克

香港2025年12月11日 /美通社/ -- 諾亞控股有限公司(Noah Holdings Limited,以下簡稱"諾亞"或"公司",紐交所代碼:NOAH,港交所代碼:6686)...

關鍵字: AI 代碼 AN 操作系統(tǒng)

弗吉尼亞州阿什本2025年12月10日 /美通社/ -- 企業(yè)技術與創(chuàng)新領域的領先合作伙伴DXC Technology(紐約證券交易所代碼:DXC)今日宣布推出AdvisoryX,這是一支旨在幫助企業(yè)應對最復雜的戰(zhàn)略、運...

關鍵字: ADVISOR AI TECHNOLOGY 代碼

新加坡2025年12月8日 /美通社/ -- 近日,51Talk在線教育集團("51Talk"或"公司")(紐約證券交易所美國股票代碼:COE)公布了其截至2025年9月...

關鍵字: BSP 代碼 創(chuàng)始人 新加坡

北京2025年12月2日 /美通社/ -- 亞馬遜云科技在2025 re:Invent全球大會上,宣布為Amazon Transform推出全新的Agent功能,以快速推進代碼和應用現代化,助力客戶更快消除技術債務,將更...

關鍵字: 亞馬遜 代碼 TRANSFORM AGENT

蘇州2025年11月10日 /美通社/ -- 在11月8日舉行的天準科技股份有限公司(股票代碼:688003)成立二十周年峰會上,一項承載深遠意義的公益計劃——"美道基金"正式發(fā)布。香港科技大學校董會...

關鍵字: AI 人工智能 代碼 智能化

模塊化是一種將復雜系統(tǒng)分解為獨立、可管理單元的軟件開發(fā)方法。在前端開發(fā)中,模塊化指的是將JavaScript代碼、樣式、模板等資源組織成獨立的功能單元。

關鍵字: 模塊化 代碼

香港2025年10月10日 /美通社/ -- 華欽科技集團公司(納斯達克代碼:CLPS,以下簡稱"華欽科技")今日宣布將于下周五2025年10月17日開盤前發(fā)布2025財年下半年及全年財報。 華欽科技集團公司簡介 華...

關鍵字: PS BSP 代碼 COM
關閉