c語言重點知識點總結
上學的時候,說起知識點,應該沒有人不熟悉吧?知識點是指某個模組知識的重點、核心內容、關鍵部分。還在苦惱沒有知識點總結嗎?下面是小編幫大家整理的c語言重點知識點總結,歡迎大家分享。
c語言重點知識點總結 篇1
◆知識點1:交換兩個變數值的方法
1)採用第三方變數(最容易想到的方法)
2)採用加減法進行值得交換(面試時常用**)
程式碼如下:
b = a - b;
a = a - b;
b = a + b;
3)採用按位異或的位方式
程式碼如下:
a = a^b;
b = a^b;
a = a^b;
◆知識點2:取語言重點知識點總結餘運算%的結果與被除的符號相同,結果為兩個正數取餘後前面加符號
◆知識點3:sizeof的使用
sizeof是一種運算子不要想當然理解為函式
sizeof使用時可以不加()
sizeof可以加變數、常量、資料型別
跟資料型別是必須加()
◆知識點4:static和 extern區別是能否進行跨檔案訪問
①函式
②變數
1、對函式的作用:
外部函式:定義的函式能被本檔案和其他檔案訪問
內部函式:定義的函式只能被本檔案訪問
預設情況下,所有函式都是外部函式(相當於帶關鍵字extern),所以可以省略
extern作用:
完整的定義和引用一個外部函式都加extern
引用時也是預設是外部函式所以也省略extern
static作用:定義一個內部函式
使用:static返回型別函式名(引數列表)
不能被其他檔案呼叫
一個專案中,本檔案的外部函式名不能和其他檔案的外部函式同名(error)
本檔案中的內部函式(static)可以和其他檔案的函式名同名的
2、對變數的作用:
全域性變數分為兩種:
外部變數:定義的變數可以被其他檔案訪問
①預設情況下所有的全域性變數都是外部變數
②不同檔案中的同名外部變數都代表同一個
③定義一個外部變數不加extern,宣告才加extern
同樣的宣告是沒有錯誤的
內部變數:定義的變數不能被其他檔案訪問
不同檔案的同名內部變數互不影響
◆知識點5:陣列的幾種初始化方式如下:
int a[3] = {10, 9, 6};
int a[3] = {10,9};
int a[] = {11, 7, 6};
int a[4] = {[1]=11,[0] = 7};(知道有此種初始化方式即可)
◆知識點6:陣列的記憶體分析和注意點
儲存空間的劃分(記憶體的分配是從高地址到低地址進行的,但一個數組內部元素又是從低到高進行的)【注:對於以後學習重要】
陣列名的作用,檢視元素地址
注意陣列不要越界
◆知識點7:字串知識點
"123”其實是由’1’、’2’、’3’、’’組成
字串的輸出”%s”,’’是不會輸出的
◆知識點8 : 字串處理函式:strlen()
計算的是字元數,不是字數
計算的字元不包括’’,一個漢字相當於3個字元
例子:"哈haha" 字元數為7
從某個地址開始的數字符個數,知道遇到’’為止
指標部分在C語言中佔據重要地位,所以重點學習與整理了指標的知識:
◆知識點9:指標定義的格式
變數型別 *變數名
如:Int *p
◆知識點10:指標作用
能夠根據一個地址值,訪問對應的.儲存空間
例:
Int *p;
Int a = 90;
P = &a;
*p = 10;//把10賦值給p所指的儲存空間
◆知識點11:指標使用注意
Int *p只能指向int型別的資料
指標變數只能儲存地址
指標變數未經初始化不要拿來間接訪問其他儲存空間
◆知識點12:指標與陣列
遍歷陣列
int ages[5] = {10, 4, 9, 44, 99};
for(int i = 0; i<5; i++)
{
printf("%d ", ages[i]);
}
使用指標遍歷陣列:
int *p;
// 指標變數P指向了陣列的首地址
p = &ages[0];
// 使用指標遍歷陣列
for(int i = 0; i<5; I++)
{
printf("ages[%d] = %d ", i, *(p + i));
}
注:指標+ 1取決於指標的型別
注:陣列的訪問方式
陣列名[下標]
指標變數名[下標]
*(p + i)
◆知識點12:指標與字串
定義字串的兩種方式:
1、利用陣列
Char name[] = “Andyzhao”
特點:字串裡的字元可以修改
適用場合:字串內容需要經常修改
2、利用指標
Char *name = “itcast”
特點:字串是一個常量,字串裡面的字元不能修改
使用場合:字串的內容不需要修改,而這個字串經常使用
◆知識點13:預處理指令(三種):
宏定義
條件編譯
檔案包含
1、宏定義的配對使用和帶引數的宏:
#define
#undef
帶引數的宏:
#define sum(v1,v2) ((v1) + (v2))//括號是必須的
例如:
#define pingfang(a) a*a
#define pingfang(a) (a*a)
呼叫時
pingfang(10)/pingfang(2)//不正確
pingfang(5+5)//不正確
帶引數的宏效率比函式高
2、條件編譯(一般是判斷宏的值)
#if 條件
#elif 條件
#else
#endif(非常重要)不然後面的程式碼全部無效
3、檔案包含:
<>表示系統自帶的檔案,""表示自定義檔案
不允許迴圈包含,比如ah包含bh,bh又包含ah
◆知識點14:typedef 只是給型別起了個別名並不是定義新型別
struct Student{
int age;
char *name;
};
typedef struct Student Student;
等價於
typedef struct Student{
int age;
char *name;
}Student;
也等價於
typedef struct {
int age;
char *name;
}Student;
類似的給列舉型別起名
typedef enum Sex
{
Man,Women
}Sex;
下面這種情況的寫法比較特殊
//下面是函式指標型別的自定義資料型別,返回值型別和引數型別要匹配
#include
typedef int (*TypeFuncPointer)(int, int);
int add(int a, intb)
{
return a + b;
}
int minus(int a, intb)
{
return a - b;
}
int main()
{
TypeFuncPointer p = add;//使用自定義型別
TypeFuncPointer p2 = minus;//使用自定義型別
printf("add = %d ",p(1, 2));
printf("minus = %d ",p2(1, 2));
return 0;
}
下面是定義結構體的指標型別
typedef struct Student{
int age;
char *name;
}*PtrStu;
//使用方式
Student stu ={18, "zhangsan"};
PtrStu p = &stu;
宏定義也是可以為型別起名的
#define Integer int
相當於
typedef int Integer
注意和typedef的區別
例如:
typedef char * String
#define String2char *