計算機二級【C語言】知識點以及常見易錯問題總結
1 分號
(1)注意每個陳述句后面需要加分號;
(2)預處理命令(非可執行命令)后面無需分號,且運用時盡量將實參加括號,避免出錯;
(3)switch陳述句以及typedef陳述句最后面加分號即可,中間無需分號(括號內除外);
2 逗號
(1)逗號運算式的值等于最后一個運算式的值;
(2)逗號運算子是一個序列點,其左邊所有副作用都結束以后,才對其右邊的運算式進行運算;i++與++i效果一樣
3 {}
(1)for陳述句、if陳述句等如果沒加括號,只與后面第一個分號之前的內容有關;
4 函式變數生命周期
(1)函式運行完之后,其變數名會被釋放,記憶體也會被釋放(標為可用),具體詳細原理可見:https://blog.csdn.net/weixin_30580341/article/details/95667655
(2)回傳值在傳遞之后其記憶體也會被釋放;
(3)malloc記憶體存放在堆里,其在函式運行之后不會被釋放;
(4)實參地址傳遞,執行完其地址不會釋放;原因:實參地址屬于函式之外的內容
5 continue&break
(1) continue陳述句是使程式跳過回圈體中剩余陳述句而進入下一次回圈,在for回圈體中還是會執行(;;)中第三塊內容中的x++或者x--等陳述句的;
(2) break陳述句只能用于回圈體內和switch陳述句內;
6 短路現象
(1)a && b :如果運算式a的值為0,則運算式b內容不執行;
(2)a || b :如果運算式a的值為1,則運算式b內容不執行;
第二章 C語言概述
(1)使用順序、選擇(分支)、回圈3種基本結構可以解決所有問題;
(2)a) 源程式(.C):C語言; b)目標程式(.obj):編譯后形成,二進制(binary); c)可執行程式(.exe):連接C語言庫函式后形成;ps:用C語言撰寫的程式稱為源程式,它以ASCII碼形式存放在一個文本檔案中;
(3)非執行陳述句不會被編譯,不會生成二進制機器指令;
(4)任何一個C語言程式都是從主函式main開始,到主函式main結束;
(5)數值常量中不能帶空格以及逗號;115L表示115是長整型資料,合法;
(6)變數必須先定義再使用;變數定義通常放在函式體前部,但也可以放在函式體或者復合陳述句開頭,不能隨意放置;
(7)運算子兩側的運算資料型別可以不一致,且結果與精度較高的保持一致;
(8)C語言是由函陣列成的;
(9)C語言區分大小寫,下標從0開始;
(10)識別符號由字母、下劃線、數字組成,且開頭必須是字母或下劃線;變數命名必須符合識別符號命名規則;
(11)C語言在運行程序中的所有計算都以二進制方式進行;C語言只接受八進制、十進制、十六進制的數;
(12)實型常量的指數形式一般形式為:E、e兩端必須要有數,其中前面為浮點數,后面為整數(數字前后都可以加正號“+”);E或e前后以及數字之間不能有空格;
(13)字串常量用雙引號,字符常量用單引號;
(14)’’ 應寫成‘\’;“\\”應寫成“\\“”;“”代表空串,合法;
(15)八進制常量以0開頭,十六進制常量以0x或者0X開頭;轉義字符可用八進制以及十六進制表示,八進制反斜線后可以不用0開頭,十六進制反斜線后只可用小寫字母x開頭;注意:八進制沒有8
(16)“int a = b= 0;” -> 錯誤,b變數還沒有定義,不能用于賦值;賦值運算子的結合方向為從右至左;
(17)C語言沒有邏輯型別,有布爾型別;整型可無誤差的表示自然數;
(18)“/”以及“/”必須成對出現,不能嵌套使用(有了“/”之后,只檢測“/”作為注釋結束),且“/”與“*”之間不能有空格;注釋可以出現在程式中的任意位置;
(19)對于識別符號的長度,C語言編譯系統規定識別符號的前若干個字符有效,超過的字符將不被識別,不同編譯系統規定的識別符號有效長度不同;
(20)unsigned是關鍵字,getch是庫函式名,都不是合法的用戶識別符號;
(21)25u屬于無符號整數;-32是十進制有符號整數;+20L是十進制形式的長整數;12f是float型別的實數;
(22)整型常量只能用數字表示,不帶小數點;實型常量必須用帶小數點的數表示,可分為小數形式以及指數形式;字符型常量是單括號括起來的單個字符;字串常量是雙括號括起來的若干個字符;
(23)轉義字符整體算一個字符,比如‘\t’代表橫向跳若干個格,‘\b’代表退格符,’\r’代表回車符,‘\n’代表換行符(‘\r\n’windows等作業系統中);
第三章 運算子與運算式
(1)強制型別轉換:(型別)常量/變數;注意括號位置
(2)“&&”兩邊任意,不一定需要整數;“++”、“–”、“!”,“<=”可以是double型別;“%”兩邊一定要int;
(3)運算式以及常量不能被賦值,即運算式以及常量不可以在等號左邊;
(4)“+”優先級高于“-=”;“<=”、“==”優先級高于“=”;
(5)如果z為int,則z=1+0.9執行后,z的值仍為1,而不是四舍五入;
(6)取模運演算法“%”以及二元運算子具有左結合性,參與運算的量均為整型,
(7)運算子兩側型別不同時,將進行隱式型別轉換;C語言中的基本運算子除了加減乘除之外,還有取余操作;
(8)自增自減運算子的優先級高于邏輯運算子,且&&運算子優先級高于||,邏輯運算子從左向右運算,故a++||b++&&c++等價于(a++)||((b++)&&(c++)),運算順序為a++、b++、c++;
(9)字符型別變數不可加減;
(10)運算優先級要注意運算層級,先乘除后加減只適用于同級運算;a+b+c*(d+e):先執行a+b得到r1.再執行(d+e)得到r2,再執行c*r2得到r3,最后執行r1+r3得出運算式的最終結果;
(11)“^”異或運算滿足一下規則:a)滿足交換律;b)一個數與0異或的結果仍是原數;c)一個數與1異或的結果是原數按位取反;
第四章 基本陳述句
(1)在輸入整數或實數這類數值型資料時輸入資料之間必須用空格、回車、換行、制表符等間隔符分開,間隔符個數不限;
(2)“%d”表示十進制格式輸出;%lf用于double型別輸入與輸出;%f用于float型別輸入,用于float以及double型別輸出(輸入時兩者不可混用);
(3)scanf()函式的格式字符前,可以加入一個正整數指定輸入資料所占的寬度,但是不可以對實數指定小數位的寬度;
(4)printf()函式的格式化字串中使用“n1.n2”的形式類指定輸出寬度(n1、n2分別代表一個長整數),其中n1代表指定輸出資料的寬度(包含小數點),n2指定小數位的位數,n2也稱為精度;當小數位數多于n2時,則四舍五入,當小數位少于n2時,則補零,
其他:
(1)陣列名不可被賦值
(2)函式地址傳遞只會改變實參地址指向的值,不會改變實參地址;函式值傳遞不會改變實參的值,
(3)預處理命令命令都以#開頭,不是可執行命令,只占用編譯時間,不占用運行時間,包含宏定義、條件編譯、檔案包含等,宏名不一定需要大寫,typrdef在編譯時處理,但是不是預處理命令,
(4)指標型別占用四個位元組(無論何種型別);檔案指標也是4個位元組;
| 型別 | 大小 |
|---|---|
| char | 1位元組 |
| bool | 1位元組 |
| short | 2位元組 |
| int | 4位元組 |
| long | 4位元組 |
| double | 8位元組 |
(5)結構體成員名不可包含其本身型別的結構體,但可以包含指向其型別變數的指標,形成鏈表,
(6)用戶識別符號可為庫函式名(預定義識別符號),但其會失效;不可為關鍵字;
(7)printf("%lf%le%hd%ld%s",……),……可為字串首地址,用以輸出從該地址之后的字串,h代表short,l代表long或者雙精度資料double,e表示指數形式、科學計數法,
(8)*在定義指標時表示說明符,在賦值時表示間址運算子,
(9)字串在定義是可以通過{“ ”}或者“ ”賦值,不管是陣列還是指標;定義后,指標只能通過“ ”賦值,陣列名不可復制,
(10)函式每一級迭代會保持相應的變數值,
(11) 0 = ‘\0’ = NULL; ++p->x = ++(p->x);
*p++=*(p++)
(12)軟體測驗用于發現程式中的錯誤,程式除錯用于診斷和改正程式中的錯誤;
(13)malloc函式結束記憶體不釋放:fgets(str,4,fp),只多輸出3個字符,自動加上‘\0’;
(14)下標從0開始,區分大小寫;
(15)fgets用于讀取長度為(n-1)個字串;fread用于讀取指定長度的資料項,對應二進制打開方式;fscanf按指定格式讀,用于文本打開方式,fseek(origin 0:開頭,1:當前,2:結尾):移動位置指標(offset +向后,-向前);rewind位置指標回到開頭;ftell獲取當前指標;feof(fp):結尾為非零值,
(16)文本打開方式 -> r:只讀;w只寫;a:從開頭讀,追加寫;+:可讀可寫;b:二進制,
(17)沒有對指標初始化,則其地址不確定,為無效指標;
(18)abs:對整數取絕對值(stdlib.h);fabs:對浮點數取絕對值(math.h);
(19)switch之后不可為double;
(20)雙向鏈表具有兩個以上的指標,但屬于線性結構,回圈佇列是順序存盤結構,回圈鏈表是鏈式存盤結構,常見線性結構有:線性表、堆疊、對列、雙佇列、陣列、串、矩陣、回圈鏈表、雙向鏈表;常見非線性結構:二維陣列、多維陣列、廣義表、樹、圖,
(21)鏈表不可通過頭、尾指標相減得到長度,兩者都為NULL則長度為0,兩者相等則長度為1;回圈佇列兩者相等則佇列為慷訓者佇列為滿,rear(尾指標)-front(頭指標)如果小于0,長度應該+m(滿空間大小),
(22)滿二叉樹為完全二叉樹,度為n的滿二叉樹,節點數為2n-1,葉子節點比度為2的節點多1,滿二叉樹第k層有2(n-1)個節點,
(23)樹的節點數 = 樹中所有節點的度的和+1;
(24)系統結構圖中-> 扇入:呼叫一個給定模塊的模塊個數;扇出:由一個模塊直接呼叫的其他模塊數,
(25)關系資料庫設計有需求分析(形成需求說明書)、概念設計(形成概念資料模型:E-R模型)、邏輯設計(形成邏輯資料模型:將E-R模型轉換為關系模型、關系視圖設計、模式規范化)、物理設計(形成資料庫內部模型:涉及軟硬體環境)、編碼、測驗、運行、進一步修改等幾個階段,
(16)關系的第一范式:每個屬性不可再分為簡單項;第二范式:每個非主屬性完全依賴于關系的某個候選鍵,消除了非主屬性對主鍵的部分依賴;第三范式:每個非主屬性不傳遞依賴于R的候選鍵,即非主屬性不可決定其他非主屬性
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/277664.html
標籤:其他
上一篇:C語言學習筆記----3
下一篇:指標典型筆試題
