博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ...
第一個程式
#include <stdio.h>
int main(){
printf("Hello World");
}
變數與常量
- 變數類型:整型【int】、字元型【char】、單精度【float】和雙精度【double】
- 整型變數
- 整型的數據在32位操作系統,所占的電腦記憶體位數為8位
- 該類型變數的定義格式如下
int 變數名=初始化值;//定義並初始化整型變數
- 在整型定義格式中、變數類型標識符int必須置於變數名之前
- 用戶定義整型變數時,也可以不用對其進行初始化操作
- 當需要定義多個整型變數時,可以用,將各個變數名隔開
int a,b,c;//定義整型類型的數據a,b,c
int m=10,n=10;//定義並初始化整型變數m,n
- 字元型:
- 通常是用於定義字元型數據的
- 該類型的變數不僅可以存儲單字元數據,還可以多字元數據或字元串
- 用戶一般直接使用字元變數標識符char就可以定義字元變數
char變數名='初始化字元';//定義並初始化單個字元
char變數名[10]="初始化字元串";//定義並初始化字元串
- 若使用單字元數據對變數進行初始化,一定要用單引號將初始化數據括起來
- 使用字元串初始化變數時,必須將變數定義為字元數組,並且用雙信號將初始化數據括起來
- 單精度
- 單精度數據類型用float表示,該類型的數據在32位操作系統中所占的電腦記憶體位數為16位
- 通常情況下,只有在進行科學計算時要使用單精度類型的數據
- 用戶在程式中,使用單精度變數標識符float定義一個f
float f=1.2545;//定義並初始化單精度變數f
- 雙精度
- 雙精度數據類型用double表示
- 該類型的數據在32位操作系統中,所占的電腦記憶體位數為32位
- 與單精度類型的數據一樣,在進行編程時,若需要進行科學計算或多位小數計算,則需要使用雙精度類型的數據
- 實際編程中,變數定義應當嚴格遵循其命名規則
- 變數名要有良好的可讀性
- 長度不宜過長
- 用戶還可以使用下劃線和首碼字元對變數進行標識
- 變數命名時,不能使用特殊符號作為變數名的首碼,也不能使用C語言中的關鍵字作為自定義變數的名稱
- 局部變數是指在一些程式段中所定義的變數,其作用範圍有很大的限制,一般只在一堆大括弧之間有作用
- 當用戶在變數定義的代碼段之外調用該變數時,是不允許的
- 這也容易導致定義的變數重名或者引用未定義的變數而發生錯誤
- 全局變數:作用域是整個程式
- 當程式運行完畢退出時,全局變數才會被自動刪除,全局變數的生命周期與程式的生命周期是相同的
- 使用全局變數時,需要根據實際情況確定全局變數的作用範圍
- 使用變數:在程式中,可以使用符號=位已經定義的變數進行賦值操作
- 輸出變數中的數據【printf語句】輸出格式
printf("格式化字元串",變數名);//輸出函數printf的原型
- 將定義的變數值輸出
#include <stdio.h>//包含頭文件
main()//主函數開始
{
int score=70;//定義並初始化整型變數
char name[]="學習C語言";//定義並初始化字元數組
float f=12.254545;//定義並初始化單精度變數
double dob;//定義雙精度變數
dob=15.526646546542;//初始化雙精度變數
printf("輸出整型數據:%d\n",score);//輸出各個變數值
printf("輸出字元串:%s\n",name);
printf("輸出單精度數據:%f\n",f);
printf("輸出雙精度數據:%1f\n",dob);
return 0;//程式正常結束
}
- 定義常量:常量是指變數值在初始化後,不能夠再進行更改【const】
- const的使用方法
const int age=10;//定義並初始化整型常量
const char ch='C';//定義並初始化字元型常量
- 實際上,關鍵字const還可以用於C語言函數及其參數中
C語言運算符
- 該運算符使用=進行標識
變數標識符=變數初始化值;//使用賦值運算符初始化變數
- 算數運算符
- 加法運算符:實現兩個數據之間的加法運算操作
數據1+數據2;//加法運算符的使用格式
- 在使用格式中,數據1和數據2的類型必須是相同的。否則,必須通過強制類型轉換將兩個數據的類型轉換成相同類型以後,才能夠使其計算的結果正確。
- 減法運算符:實現兩個數據之間的減法運算操作
數據1-數據2;//減法運算符的使用格式
- 乘法運算符:實現兩個數據的乘法運算
數據1*數據2;//乘法運算符的使用格式
- 除法運算符:使用符號/標識,表示計算兩個數據之間的商
商=數據1/數據2;//除法運算符使用格式
- 邏輯運算符:實現數據間的邏輯運算操作
- 邏輯與和邏輯或的運算規則
- 邏輯非的運算規則
- 關係運算符:兩個表達式或者變數進行比較
- 大於(>)
- 小於(<)
- 大於等於(>=)
- 小於等於(<=)
- 不等於(!=)
- 等於(==)
- 三目運算符:唯一一個有三個變數同時參與運算的運算符
<表達式1>?<表達式2>:<表達式3>//三目運算符使用格式
- 表達式1表示三目運算符的運算條件
- 程式將該運算條件的真假,對後面的取值進行選擇
- 如果表達式1的值為真,則三目運算符的運行結果為表達式2,否則運算結果將為表達式3
- 位運算符:針對每個二進位數據位
- 按位與(&)
- 按位或(|)
- 按位異或(^)
- 左移(<<)
- 右移(>>)
- 位運算符具體作用
- 單目運算符:該運算符只被用於單個數據的運算,參與運算的數據只有一個
- 前置單目運算符是指運算符在數據之前,即使用格式運算符運算數據
- 後置單目運算符:常用的前置單目運算符也可以將運算符放到運算數據之後,作為後置單目運算符使用
標準輸入/輸出
- scanf概述
- C語言中最為常用的標準輸入函數
- 主要是從電腦的輸入流中獲取相應的數據,並將獲取到的數據保存在用戶指定的變數或者記憶體中
- 用戶在使用函數scanf時,需要使用輸入控制符控制數據的獲取
int scanf(const char *format,ch);//輸入函數scanf的使用原型
- 當函數調用成功時,將返回獲取到數據的個數
- 參數format表示了格式控制符,主要用於控制獲取數據的類型,當然,該參數也可以是一個格式空支付的組合字元串
- 參數ch表示了一個已經定義的變數,即將獲取到的數據放到該參數所指向的變數地址中進行保存
- 用戶可以使用關鍵字include將指定的頭文件包含到程式中,並且標準輸入函數scanf定義和實現均包含在頭文件stdio.h
#include <stdio.h>//包含相應的頭文件
- 用戶在包含頭文件時,若頭文件為系統定義的,則需要使用尖括弧“<>”將文件名括起來;若頭文件為自定義的,則使用雙引號將文件名括起來。
- printf概述
- 參數format表示輸出格式控制符,主要是控制輸出字元的格式
- 參數ch表示將要輸出的變數
- getchar()
- C語言中用於獲取單個輸入數據的功能的函數
- 當用戶在程式中輸入一串字元時,該函數也只能夠獲取到輸入的第一個字元數據,而後面的字元將被省略
int getchar(void);//獲取單個數據
- 如果該函數調用成功,則將返回獲取到的數據;否則,將返回0
- 使用putchar()
- 該函數只能夠向電腦輸出設備輸出一個數據,並且該函數也可以在迴圈結構中使用
int putchar(int c);//輸出單個數據
- 在該函數,含有一個參數c,表示存放輸出數據的變數標識符。如果該函數調用失敗,將返回錯誤標識符EOF
C語言控制結構
- if...else結構的運行原理
- while迴圈流程圖
- do...while迴圈結構執行流程圖
- 關鍵字break常被用於迴圈功能代碼中,其主要作用是調處並終止迴圈結構的運行
- 關鍵字continue的具體功能比較豐富,即終止用戶所指定的本次迴圈,但不會跳出迴圈結構,從而可以繼續執行下一個迴圈
- switch...case開關結構流程圖
- 轉義字元是指C語言中能夠實現特定功能的輸出控制字元
- 數據類型輸出控制符包括格式控制符和格式字元
- 常用的格式字元
函數
- 函數包括參數和返回值
- 參數是用於向函數內部傳遞數據的
- 返回值是將函數處理後的結果傳遞到函數外部
- 函數在定義時,也需要具有一定的定義格式。在定義格式中,包含函數的名稱、參數類型、參數個數和函數返回值
返回類型 函數名(參數類型 參數1,參數類型 參數2);//函數定義
- 函數返回值和參數類型的具體取值及其意義
- 根據函數參數的使用位置不同,其種類有實參和形參兩種
- 實參是在用戶調用函數時,傳遞給函數的實際參數
- 形參則是在函數定義時,所設置的形式參數,該類型的參數並不具有實際意義,只是一個標識
- 用戶使用函數形參實現自定義函數的定義
void add(int a,int b);//自定義函數
- 當然,用戶也可以在函數定義時,只使用數據類型作為函數形參
void add(int,int);//使用數據類型作為函數形參
- 函數的返回值可以將函數內部的運算結果等變數值傳遞到函數外部
- 函數返回值就是函數內部與外部通信的一個橋梁,而函數參數是函數外部與內部通信的橋梁
- 變數的作用域和生存周期是其定義位置所在的一對大括弧{}之內
- 根據自定義函數的調用位置和調用順序的不同,其調用方式也會有所不同
- 自定義函數的直接調用,優點在於調用簡單、方便、直觀。但是,在需要多次調用函數實現一個功能的時候,用戶就需要顯示地多次調用該函數,這種調用方式將容易造成代碼量的增加以及程式運行的不可控制性
- 函數的遞歸調用是指在一個自定義函數中再嵌套使用相同函數,以實現迴圈調用相同函數的功能