C語言程序設計 課件 任務3.3 編程規范_第1頁
C語言程序設計 課件 任務3.3 編程規范_第2頁
C語言程序設計 課件 任務3.3 編程規范_第3頁
C語言程序設計 課件 任務3.3 編程規范_第4頁
C語言程序設計 課件 任務3.3 編程規范_第5頁
已閱讀5頁,還剩19頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

C語言程序設計基礎與實踐模塊二編程初級應用任務3.3

編程規范C語言程序設計基礎與實踐課程組04技能點拓展03技能點詳解02技能點分析目錄CONTENTS任務3.3編程規范01問題引入05技能點檢測一問題引入

大江東流,日月交替,大自然生生不息,用規則演繹著生命的軌跡。火車之所以能夠奔馳千里,是因為它始終離不開兩條鐵軌;風箏之所以能高高飛翔,是因為它總是情系著手中的線;宇宙間無數顆恒星亙古不變地燦爛,是因為它們都按照自己的軌道運行。不以規矩,不成方圓。我們要編寫一個高質量的代碼,就必須遵守一定的規范,這樣才能保證代碼的易讀性和易維護性。那么規范化的編程有哪些要求呢?04技能點拓展03技能點詳解02技能點分析目錄CONTENTS01問題引入05技能點檢測任務3.3編程規范二技能點分析1.了解C語言編程的基本規范2.能夠使用簡化版本對程序注釋3.能夠使用編程規范編寫代碼學習目標1.程序編寫過程種,為什么需要注意代碼的規范化?2.代碼規范化主要體現在那幾個方面?3.文件注釋的完整版本的規范寫法是什么?4.函數注釋的完整版本的規范寫法是什么?

學期預習04技能點拓展03技能點詳解02技能點分析目錄CONTENTS01問題引入05技能點檢測任務3.3編程規范三技能點詳解

代碼規范化的原則是在遵守編譯器要求的代碼規范下,追求代碼整體清晰、美觀、易閱讀、易排錯,有利于團隊程序開發。一般來說,規范化主要從結構、排版、注釋、命名四個方面入手。三技能點詳解——1結構每個C程序通常分為兩個文件。一個文件用于保存程序的聲明,稱為頭文件。另外一個文件用于保存程序的實現,稱之為定義文件。C程序的頭文件以“.h”為后綴,C程序的定義文件以“.c”為后綴。/************************************函數聲明:文件名,版本,歷史信息等信息***********************************//*頭文件包含*/#include

<xxxxx.h>

#include

"xxxxx.h"

/*變量定義*/intnum_man;

/*函數聲明*/voidsum_add(void);

/*主函數*/voidmain(void){sum_add();//子函數使用

}

/************************************函數聲明:文件名,函數版本等信息***********************************/voidsum_add(void)/*子函數*/

{

//子函數體}1)空行

空行起著分隔程序段落的作用,空行得體將使程序的布局更加清晰。兩個相對獨立的程序塊、定義變量后必須要加空行。比如上面幾行代碼完成的是一個功能,下面幾行代碼完成的是另一個功能,那么它們中間就要加空行。voidDemoFunc(void){ uint8_ti;

//局部變量和語句間空一行

/*功能塊1*/

for(i=0;i<10;i++) {

//... }

//不同的功能塊間空一行

/*功能塊2*/

for(i=0;i<20;i++) {

//... }}三技能點詳解——2排版2)空格

在兩個以上的關鍵字、變量、常量進行對等操作時,它們之間的操作符之前、之后或者前后要加空格;(1)逗號、分號只在后面加空格。inta,b,c;(2)比較操作符,賦值操作符"="、"+=",算術操作符"+"、"%",邏輯操作符"&&"、"&",位域操作符"<<"、"^"等雙目操作符的前后加空格。if

(current_time>=MAX_TIME_VALUE)a=b+c;a*=2;a=b^2;(3)"!"、"~"、"++"、"--"、"&"(地址運算符)等單目操作符前后不加空格。*p='a';//內容操作"*"與內容之間flag=!isEmpty;//非操作"!"與內容之間p=&mem;//地址操作"&"與內容之間i++;//"++","--"與內容之間(4)"->"、"."前后不加空格。p->id=pid;//"->"指針前后不加空格(5)if、for、while、switch等與后面的括號間應加空格,使if等關鍵字更為突出、明顯,函數名與其后的括號之間不加空格,以與保留字區別開。if(a>=b&&c>d)三技能點詳解——2排版3)對齊

成對的符號一定要成對書寫,如()、{}。不要寫完左括號然后寫內容最后再補右括號,這樣很容易漏掉右括號,尤其是寫嵌套程序的時候。{和}分別都要獨占一行。#include

<stdio.h>intmain(void){

if(…)

return0;}三技能點詳解——2排版4)代碼行

一行代碼只做一件事情,如只定義一個變量,或只寫一條語句。這樣的代碼容易閱讀,并且便于寫注釋。if、else、for、while、do等語句自占一行,執行語句不得緊跟其后。#include

<stdio.h>

intmain(void){

if(…-){

while(…-)}

return0;}三技能點詳解——2排版三技能點詳解——3注釋行注釋一行注釋采用//…,多行注釋必須采用/*…*/。在一般情況下,源程序有效注釋量必須在20%以上。/*變量定義*/intnum_man;//班級男生人數0~50之間

a=a+1;//a自身加1(沒有必要)文本注釋主要針對整個文件進行的注釋,這個注釋內容較多,便于閱讀者快速了解文件的相關信息。/****************************************************************Copyright(C),2021-2023,C語言項目開發組*文件名:main.c*內容簡述:實現小球沿著不同方向碰撞墻壁,并實現反彈。*文件歷史:*版本

日期

作者

說明*1.02021-12-01課題組

實現小球的碰撞轉向*2.02022-06-12課題組

采用函數,優化程序****************************************************************/

針對一些練習用的小函數,不需要填寫全部信息,可以采用簡化版本。/****************************************************************內容簡述:根據給定的年、月、日計算是星期幾?需要采用基姆拉爾森算法。*Weekday=(d+2*m+3*(m+1)/5+y+y/4-y/100+y/400)%7****************************************************************/三技能點詳解——3注釋函數注釋主要針對一個函數進行的注釋,這個注釋內容較多,便于閱讀者快速了解函數的相關信息。在函數實現之前,應該給出和函數的實現相關的足夠而精練的注釋信息。內容包括本函數功能介紹,調用的變量、常量說明,形參說明,特別是全局變量。/***************************************************************函數名:voidPositionBall(intx,inty)*功

能:在不同位置繪制小球*輸

入:小球的x方向的坐標window_left--window_right*小球y方向的坐標window_top--window_bottom*輸

出:無**************************************************************/針對一些練習用的小程序,不需要如此嚴格,可以采用簡化版本。/***************************************************************功

能:根據輸入年月日,計算星期**************************************************************/三技能點詳解——3注釋命名主要是標識符的命名,命名要清晰、明了,有明確含義,同時使用完整的單詞或大家基本可以理解的縮寫,避免使人產生誤解。temp可縮寫為tmp;

flag可縮寫為flg;

message可縮寫為msg;statistic可縮寫為stat;

increment可縮寫為inc;

unsigned

chardat01;//修改unsignedcharliv_date;voidSet00(unsigned

charc);//修改voidSetName(unsignedcharc);

intClass_width;//局部整形變量,教室寬度charStudent_name;//全局字符型變量,學生名字函數命名,單詞詞間首字母大寫,voidCommInit();三技能點詳解——4命名案例1.2.1簡化規范根據給定的年、月、日計算是星期幾?需要采用基姆拉爾森算法,算法公式如下Weekday=(d+2*m+3*(m+1)/5+y+y/4-y/100+y/400)%7。針對一些練習用的小程序,我們采用簡化規范,簡化規范主要體現在注釋上面。三技能點詳解——5案例見教材內容!案例1.2.2標準規范

針對一些能夠進行拓展的程序,我們需要較為詳細的注釋,確保程序的可讀性和可移植性,我們進行標準的規范。

實現小球沿著不同方向碰撞墻壁,并實現反彈。三技能點詳解——5案例見教材內容!04技能點拓展03技能點詳解02技能點分析目錄CONTENTS01問題引入05技能點檢測任務3.3編程規范四技能點拓展——1頭文件路徑在引用頭文件時,不要使用絕對路徑。如果使用絕對路徑,當需要移動目錄時,必須修改所有相關代碼,繁瑣且不安全;使用相對路徑,當需要移動目錄時,只需修改編譯器的某個選項即可。#include“/project/inc/hello.h”//不應使用絕對路徑#include“../inc/hello.h”//可以使用相對路徑在引用頭文件時,使用<>來引用預定義或者特定目錄的頭文件,使用“”來引用當前目錄或者路徑相對于當前目錄的頭文件。#include

<stdio.h>

//標準頭文件#include

<projdefs.h>

//工程指定目錄頭文件

#include“global.h”//當前目錄頭文件#include“inc/config.h”//路徑相對于當前目錄的頭文件為了防止頭文件被重復引用,應

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論