第一個程式
#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);//使用資料型別作為函式形參
- 函式的回傳值可以將函式內部的運算結果等變數值傳遞到函式外部
- 函式回傳值就是函式內部與外部通信的一個橋梁,而函式引數是函式外部與內部通信的橋梁
- 變數的作用域和生存周期是其定義位置所在的一對大括號{}之內
- 根據自定義函式的呼叫位置和呼叫順序的不同,其呼叫方式也會有所不同
- 自定義函式的直接呼叫,優點在于呼叫簡單、方便、直觀,但是,在需要多次呼叫函式實作一個功能的時候,用戶就需要顯示地多次呼叫該函式,這種呼叫方式將容易造成代碼量的增加以及程式運行的不可控制性
- 函式的遞回呼叫是指在一個自定義函式中再嵌套使用相同函式,以實作回圈呼叫相同函式的功能
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/473395.html
標籤:C
