湖南大學(xué)829考研資料829-c語言簡答題_h_第1頁
湖南大學(xué)829考研資料829-c語言簡答題_h_第2頁
湖南大學(xué)829考研資料829-c語言簡答題_h_第3頁
湖南大學(xué)829考研資料829-c語言簡答題_h_第4頁
湖南大學(xué)829考研資料829-c語言簡答題_h_第5頁
已閱讀5頁,還剩7頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、一、簡答部分:(*號為重點(diǎn)程度)1. 關(guān)鍵字和一般標(biāo)識符有什么不同?(*)標(biāo)識符使用來標(biāo)識源程序中的某個對象的名字的,一個標(biāo)識符由字母、數(shù)字和下劃線組成關(guān)鍵字可以定義變量、表達(dá)語句功能和對一些文件進(jìn)行預(yù)處理,關(guān)鍵字已被編譯系統(tǒng)本身使用,所以用戶編寫程序時不能夠使用這些關(guān)鍵字來作為標(biāo)識符,如unsigned char,int,long,if,for,include,define 等。2. if 語句中的條件表達(dá)式可以是任意合法的表達(dá)式嗎? switch 語句中break 的作用是什么?(*)可以是任意數(shù)值。在 switch 語句中,break 語句可使流程立即跳出 switch 語句體不執(zhí)行其他

2、的 case。3. 三種循環(huán)結(jié)構(gòu)中的條件是循環(huán)進(jìn)行的條件還是循環(huán)結(jié)束的條件?循環(huán)結(jié)構(gòu)中break 語句和 continue 語句的作用是什么,二者有何區(qū)別?(*)for 語句、while 語句:循環(huán)進(jìn)行的條件;do-while 語句:循環(huán)結(jié)束的語句。break 可用于 switch 語句,表示跳出整個 switch 塊,而 continue 則不能用于switch 語句它們都可用于循環(huán)語句的循環(huán)體,break 用于立即退出當(dāng)前循環(huán),而 continue僅跳過當(dāng)次循環(huán),本次循環(huán)體內(nèi)不執(zhí)行 continue 語句后的其它語句,但下次循環(huán)還會執(zhí)行。4.字符數(shù)組與字符串是否相同?若不相同,有何區(qū)別?(

3、*)不相同,C 語言中沒有專門的字符串變量,如果要將一個字符串存放在變量中,必須使用字符數(shù)組,即用一個字符型數(shù)組來存放一個字符串,數(shù)組中每一個元素存放一個字符。字符串:必須以0結(jié)尾,字符數(shù)組:可以包含多個0。15.函數(shù)的嵌套調(diào)用與遞歸調(diào)用有什么區(qū)別?(*)函數(shù)嵌套允許在一個函數(shù)中調(diào)用另外一個函數(shù),遞歸調(diào)用是調(diào)用本身的函數(shù)。函數(shù)嵌套就是函數(shù)調(diào)用函數(shù),是普遍的,遞歸就是函數(shù)調(diào)用自身,是函數(shù)嵌套的一個特例。6.結(jié)構(gòu)體類型與我們前面學(xué)過的基本類型有哪些區(qū)別?(*)結(jié)構(gòu)體是一個可以包含不同數(shù)據(jù)類型的一個結(jié)構(gòu),它是一種可以自己定義的數(shù)據(jù)類型。特點(diǎn):第一:結(jié)構(gòu)體可以在一個結(jié)構(gòu)中聲明不同的數(shù)據(jù)類型;第二:相同

4、結(jié)構(gòu)的結(jié)構(gòu)體變量是可以相互賦值的,而數(shù)組是做不到的,因?yàn)閿?shù)組是單一數(shù)據(jù)類型的數(shù)據(jù)集合,它本身不是數(shù)據(jù)類型(而結(jié)構(gòu)體是),數(shù)組名稱是常量指針,所以不可以做為左值進(jìn)行運(yùn)算,所以數(shù)組之間就不能通過數(shù)組名稱相互復(fù)制了,即使數(shù)據(jù)類型和數(shù)組大小完全相同。第三:節(jié)省內(nèi)存空間第四:高效率。7.指針與地址有什么聯(lián)系?在使用指針的過程中應(yīng)注意哪些細(xì)節(jié)?指針類型對于程序設(shè)計(jì)有哪些意義?(*)指針保存了某個變量的地址,指針本身是一個變量,它也有自身的地址, 而指針的內(nèi)容是某個變量的地址。注意細(xì)節(jié): 要初始化、正確的傳遞地址方式、使用時要判斷。指針可以用來有效地表示復(fù)雜的數(shù)據(jù)結(jié)構(gòu),可以用于函數(shù)參數(shù)傳遞并達(dá)到更加靈活使用

5、函數(shù)的目的.使 C 語言程序的設(shè)計(jì)具有靈活、實(shí)用、高效的特點(diǎn)。28. 堆和棧的概念和區(qū)別?(*)棧區(qū)(stack) 由編譯器自動分配釋放 ,存放函數(shù)參數(shù)值,局部變量的值等。其操作方式類似于數(shù)據(jù)結(jié)構(gòu)中的棧。堆區(qū)(heap) 一般由程序員分配釋放 , 若程序員不釋放,程序結(jié)束時可能由 OS 回收 。注意它與數(shù)據(jù)結(jié)構(gòu)中的堆是兩回事,分配方式倒是類似于鏈表。全局區(qū)(靜態(tài)區(qū))(static),全局變量和靜態(tài)變量的存儲是放在一塊的,初始化的全局變量和靜態(tài)變量在一塊區(qū)域,未初始化的全局變量和未初始化的靜態(tài)變量在相鄰的另一塊區(qū)域。 - 程序結(jié)束后由系統(tǒng)釋放文字常量區(qū) 常量字符串就是放在這里的。 程序結(jié)束后由系

6、統(tǒng)釋放程序代碼區(qū)存放函數(shù)體的二進(jìn)制代碼。堆與棧的區(qū)別很明顯:1.棧內(nèi)存存儲的是局部變量而堆內(nèi)存存儲的是實(shí)體;2.棧內(nèi)存的更新速度要快于堆內(nèi)存,因?yàn)榫植孔兞康纳芷诤芏蹋?.棧內(nèi)存存放的變量生命周期一旦結(jié)束就會被釋放,而堆內(nèi)存存放的實(shí)體會被垃圾回收機(jī)制不定時的回收。9.C 語言中指針與數(shù)組的區(qū)別(*)數(shù)組要么在靜態(tài)存儲區(qū)被創(chuàng)建(如全局?jǐn)?shù)組) ,要么在棧上被創(chuàng)建。數(shù)組名對應(yīng)著(而不是指向)一塊內(nèi)存,其地址與容量在生命期內(nèi)保持不變,只有數(shù)組的內(nèi)容可以改變。指針可以隨時指向任意類型的內(nèi)存塊,它的特征是“可變” ,所以我們常用指針來操作動態(tài)內(nèi)存。指針遠(yuǎn)比數(shù)組靈活,但也更危險(xiǎn)。10.關(guān)鍵字 const

7、的含義及其作用(*)const 是一個修飾符,被修飾的對象或者變量是不可修改的,也就是說 const可讀不可改,const 在誰的后面 const 就修飾誰,如果 const 在最前面,那么將 const后移一位即可,二者是等效的。const 有以下這幾個作用:31.如果我們想要阻止一個變量被改變,那么我們就可以使用 const 關(guān)鍵字來修飾它,由于被 const 修飾的對象或者變量是可讀不可寫的,因此我們在使用 const的使用要對所修飾的對象或者變量進(jìn)行初始化,否則以后沒有機(jī)會再改變他的值。2.對于指針來說,const 可以修飾指針本身,也可以修飾指針?biāo)傅臄?shù)據(jù),也可以修飾兩者。3.在對一

8、個函數(shù)進(jìn)行聲明的時候,可以使用 const 對形參進(jìn)行修飾,表明它是一個輸入?yún)?shù),在函數(shù)的內(nèi)部不可寫。對于類的成員函數(shù),如果被 const 修飾,表明它是一個常函數(shù),不能修改類的成員變量。4. 對于類的成員函數(shù),有時候必須指定其返回值類型是 const,這樣使得該函數(shù)的返回值不是“左值”。11.請說出 const 與#define 相比,有何優(yōu)點(diǎn)?(*)const 作用:定義常量、修飾函數(shù)參數(shù)、修飾函數(shù)返回值三個作用。被 Const 修飾的東西都受到強(qiáng)制保護(hù),可以預(yù)防意外的變動,能提高程序的健壯性。1.const 常量有數(shù)據(jù)類型,而宏常量沒有數(shù)據(jù)類型。編譯器可以對前者進(jìn)行類型安全檢查。而對后者

9、只進(jìn)行字符替換,沒有類型安全檢查,并且在字符替換可能會產(chǎn)生意料不到的錯誤。2.有些集成化的調(diào)試工具可以對 const 常量進(jìn)行調(diào)試,但是不能對宏常量進(jìn)行調(diào)試。12. 什么是預(yù)編譯?何時需要預(yù)編譯?(*)預(yù)編譯又稱為預(yù)處理 , 是做些代碼文本的替換工作。處理以#開頭的指令 , 比如拷貝#include 包含的文件代碼,#define 宏定義的替換,條件編譯等,就是為編譯做的預(yù)備工作的階段。主要處理#開始的預(yù)編譯指令,預(yù)編譯指令指示了在程序正式編譯前就由編譯器進(jìn)行的操作,可以放在程序中的任何位置。4C 編譯系統(tǒng)在對程序進(jìn)行通常的編譯之前,首先進(jìn)行預(yù)處理。c 提供的預(yù)處理功能主要有以下三種:1宏定義

10、2文件包含3條件編譯何時需要預(yù)編譯:總是使用不經(jīng)常改動的大型代碼體。程序由多個模塊組成,所有模塊都使用一組標(biāo)準(zhǔn)的包含文件和相同的編譯選項(xiàng)。在這種情況下,可以將所有包含文件預(yù)編譯為一個“預(yù)編譯頭”13.C 語言中,變量為何要先定義后使用?(*)凡是未被事先定義的不作為變量名,這就能保證程序中變量名使用得正確,便于編譯時發(fā)現(xiàn)錯誤,避免變量名使用時出錯。每個變量被指定一確定類型,在編譯時就能為其分配相應(yīng)的存儲單元。指定每一個變量屬于一個類型,便于在編譯時據(jù)此檢查該變量所進(jìn)行的運(yùn)算是否合法。14.舉例說明在 C 語言中如何定義符號常量,使用符號常量的優(yōu)點(diǎn)?(*)#define 例如:#define A

11、GE 35#define M 1.9734067e9優(yōu)點(diǎn):1)簡化書寫格式、減少出錯率。2)定義符號常量可以提高程序的可讀性,便于程序的調(diào)試和修改。3)符號常量不同于變量,在其作用域內(nèi)不能被改變和重新賦值。4)習(xí)慣上人們把符號常量名用大寫字母表示,變量用小寫,以示區(qū)別。15.字符串是以0結(jié)束的,存儲一個字符串需要多少個字節(jié)?(*)如“ABC”實(shí)際需要 3+1 個字節(jié)來存儲這個字符串常量。16.while和 do while 兩種循環(huán)結(jié)構(gòu)的相同點(diǎn)和不同點(diǎn)是什么?(*)5do-while 語句和 while 語句的區(qū)別在于 do-while 是先執(zhí)行后判斷,因此do-while 至少要執(zhí)行一次循環(huán)

12、體。而 while 是先判斷后執(zhí)行,如果條件不滿足,則一次循環(huán)體語句也不執(zhí)行。while 語句和 do-while 語句一般都可以相互轉(zhuǎn)換。17.C 語言中,什么基本數(shù)據(jù)類型不能做 switch()的參數(shù)?(*)只能針對基本數(shù)據(jù)類型使用 switch,這些類型包括 int、char 等。對于其他類型如 long /float /double,則必須使用 if 語句。18.二維數(shù)組的定義和初始化的正確形式有哪些?(*)1.分行,如:int a34=1,2,3,4,5,6,7,8,9,10,11,12;2.按數(shù)組排列的順序?qū)⑺袛?shù)據(jù)寫在一個花括號內(nèi),如:int a34=1,2,3,4,5,6,7,

13、8,9,10,11,12;3.部分元素初始化。如:int a34= ,1,0,6,0,0,11;4.如果對全部元素都賦初值,則定義數(shù)組時可以不指定第一維的長度,如:int a4=1,2,3,4,5,6,7,8,9,10,11,12;19.C 語言中進(jìn)行函數(shù)聲明的作用是什么?(*)函數(shù)聲明的作用是:把函數(shù)的名字、函數(shù)類型及形參類型、個數(shù)和順序編譯系統(tǒng),以便在調(diào)用該函數(shù)時系統(tǒng)按此進(jìn)行對照和檢查(例如,函數(shù)名是否正確,實(shí)參的類型和個數(shù)是否一致)。20.帶參的宏與函數(shù)有什么區(qū)別?(*)1.函數(shù)調(diào)用,求出實(shí)參表達(dá)式的值,再帶入形參。而宏只進(jìn)行簡單的字符替換。2.函數(shù)調(diào)用是在程序運(yùn)行時處理的,分配臨時的內(nèi)

14、存單元;而宏展開則是在編譯時進(jìn)行的,在展開時并不分配內(nèi)存單元,不進(jìn)行值的傳遞處理,也沒有“返回值”的概念。63.對函數(shù)中的實(shí)參和形參都要定義類型,二者的類型要求一致,如不一致,應(yīng)進(jìn)行類型轉(zhuǎn)換;而宏不存在類型問題,無類型,只是一個符號代表,展開時帶入指定的字符即可。宏定義時,字符串可以是任何類型的數(shù)據(jù)。4.調(diào)用函數(shù)只可得到一個返回值,而用宏可以設(shè)法得到幾個結(jié)果。#include #define PI 3.1415926#define CIRCLE(R,L,S,V) L=2*PI*R;S=PI*R*R;V=4.0/3.0*PI*R*R*Rvoid main()float r,l,s,v;scanf

15、(%f,&r);CIRCLE(r,l,s,v);printf(r=%6.2f,l=%6.2f,s=%6.2f,v=%6.2fn,r,l,s,v);5.使用宏次數(shù)多時,每展開一次都使程序增長,而函數(shù)調(diào)用不使源程序變長。6.宏不占運(yùn)行時間,只占編譯時間;函數(shù)占運(yùn)行時間(分配、保留、值傳遞、返回)。21.C 語言變量的存儲特性可分幾類?以及各類的特點(diǎn)?(*)四種:自動變量(auto)、靜態(tài)變量(static)、外部變量(extern)以及寄存器變量(register)。1.自動變量:函數(shù)中所有的非靜態(tài)局部變量。其作用域僅僅局限于其定義的函數(shù)中,存儲在動態(tài)存儲區(qū),在沒有顯式初始化的時候,其變量的值是隨

16、機(jī)無用的。隨著函數(shù)的進(jìn)棧和出棧而創(chuàng)建和銷毀。2.靜態(tài)變量:在變量前加上 static 關(guān)鍵字的變量。存儲在靜態(tài)存儲區(qū),在沒有顯式初始化的時候會被初始化為 0 或者 null,并且只初始化一次(初始化不等同于賦值)。長期存在靜態(tài)存儲區(qū),直到程序結(jié)束靜態(tài)全局變量:作用域只是在其定義的源文件中有效,對外部變量起到了“屏7蔽”的作用。靜態(tài)局部變量:其作用域是其定義的函數(shù)中。3、外部變量:一般用作全局變量作用域的擴(kuò)展。把全局變量在其他源文件中聲明成 extern 變量,可以擴(kuò)展該全局變量的作用域至聲明的那個文件,其本質(zhì)作用就是對全局變量作用域的擴(kuò)展。長期存在靜態(tài)存儲區(qū),直到程序結(jié)束。4、寄存器變量:一般

17、經(jīng)常被使用的的變量(如某一變量需要計(jì)算幾千次)可以設(shè)置成寄存器變量,register 變量會被存儲在寄存器中,計(jì)算速度遠(yuǎn)快于存在內(nèi)存中的非 register 變量。存儲在 cpu 的寄存器中,速度快,一般不需要程序員定義寄存器變量,這是由于一些編譯器會把需要參加很多次計(jì)算的變量轉(zhuǎn)化成寄存器變量,不允許程序員對寄存器變量的地址進(jìn)行操作。離開函數(shù)值就會消失。22.C 語言中,動態(tài)存儲區(qū)主要存放哪些數(shù)據(jù)?(*)動態(tài)存儲區(qū)中存放以下數(shù)據(jù):函數(shù)的形參;函數(shù)調(diào)用時的現(xiàn)場保護(hù)和地址等;auto/register 型局部變量。對以上數(shù)據(jù),當(dāng)進(jìn)行函數(shù)調(diào)用時分配動態(tài)存儲空間,當(dāng)函數(shù)調(diào)用結(jié)束時,釋放這些存儲單元。在

18、程序的執(zhí)行過程中,這種分配和釋放是動態(tài)的。23. static 聲明有什么用途 (請至少說明兩種)?static 全局變量與普通的全局變量有什么區(qū)別?static 局部變量和普通局部變量有什么區(qū)別?static 函數(shù)與普通函數(shù)有什么區(qū)別?(*)1.限制變量的作用域;設(shè)置變量的存儲域;2.全局變量的說明之前再加以 static 就構(gòu)成了靜態(tài)的全局變量。全局變量本身就是靜態(tài)存儲方式,靜態(tài)全局變量當(dāng)然也是靜態(tài)存儲方式。這兩者在存儲方式上并無不同。這兩者的區(qū)別雖在于非靜態(tài)全局變量的作用域是整個源程序,當(dāng)一個源程序由多個源文件組成時,非靜態(tài)的全局變量在各個源文件中都是有效的。而靜態(tài)全局變量則限制了其作用

19、域,即只在定義該變量的源文件內(nèi)有效,在同一源程序的其它源文件中不能使用它。由于靜態(tài)全局變量的作用域局限于一個源文件內(nèi),只能為該源文件內(nèi)的函數(shù)公用,因此可以避免在其它源文件中引起錯誤。從以上分析可8以看出,把局部變量改變?yōu)殪o態(tài)變量后是改變了它的存儲方式即改變了它的生存期。把全局變量改變?yōu)殪o態(tài)變量后是改變了它的作用域, 限制了它的使用范圍;3.static 局部變量只被初始化一次,下一次依據(jù)上一次結(jié)果值;4.static 作用域僅在本文件。只在當(dāng)前源文件中使用的函數(shù)應(yīng)該說明為內(nèi)部函數(shù)(static),內(nèi)部函數(shù)應(yīng)該在當(dāng)前源文件中說明和定義。對于可在當(dāng)前源文件以外使用的函數(shù),應(yīng)該在一個頭文件中說明,要

20、使用這些函數(shù)的源文件要包含這個頭文件。static 函數(shù)在內(nèi)存中只有一份,普通函數(shù)在每個被調(diào)用中維持一份拷貝程序的局部變量存在于(堆棧)中,全局變量存在于(靜態(tài)區(qū))中,動態(tài)申請數(shù)據(jù)存在于(堆)中。24.使用全局變量的優(yōu)點(diǎn)和副作用是什么?(*)優(yōu)點(diǎn):所有函數(shù)之前定義的全局變量可被本文件中所有函數(shù)共用;全局變量的有效范圍是它定義的位置到本源文件結(jié)束;全局變量增加了函數(shù)之間的聯(lián)系通道;全局變量與局部變量重名時,在函數(shù)內(nèi)部將全局變量。副作用:過多的全局變量時函數(shù)之間的“耦合性”增加,不利于程序的移植;過多的全局變量使程序的可讀性變差;外部變量可加強(qiáng)函數(shù)模塊之間的數(shù)據(jù)聯(lián)系,但又使這些函數(shù)依賴這些外部變量

21、,因而使得這些函數(shù)的獨(dú)立性降低;從模塊化程序設(shè)計(jì)的觀點(diǎn)來看這是不利的,因此不是非用不可時,建議不要使用外部變量;全局變量在程序執(zhí)行的全過程都占用存儲單元。25.指針有哪些運(yùn)算?以及指針編程的優(yōu)點(diǎn)?(*)算術(shù)運(yùn)算、關(guān)系運(yùn)算、賦值;提高程序的編譯效率和執(zhí)行速度;可向調(diào)用函數(shù)處返回除正常的返回值之外的其他數(shù)據(jù),從而實(shí)現(xiàn)兩者間的雙向通信;利用指針可以實(shí)現(xiàn)動態(tài)內(nèi)存分配;直接操縱內(nèi)存地址;更容易實(shí)現(xiàn)函數(shù)的編寫和調(diào)用。926.C 語言中,*(星號)運(yùn)算符有幾種用途?并分別舉例說明。(*)指針符號;乘法運(yùn)算符;字符;注釋。27.什么是算法?(*)算法(Algorithm)是指解題方案的準(zhǔn)確而完整的描述,是一系

22、列解決問題的清晰指令,算法代表著用系統(tǒng)的方法描述解決問題的策略機(jī)制。也就是說,能夠?qū)σ欢ㄒ?guī)范的輸入,在有限時間內(nèi)獲得所要求的輸出。如果一個算法有缺陷,或不適合于某個問題,執(zhí)行這個算法將不會解決這個問題。不同的算法可能用不同的時間、空間或效率來完成同樣的任務(wù)。一個算法的優(yōu)劣可以用空間復(fù)雜度與時間復(fù)雜度來衡量。28. 一個完整的算法應(yīng)該具有哪幾個基本性質(zhì)?(*)算法的一般性質(zhì)包括:(1)通用性 對于那些符合輸入類型的任意輸入數(shù)據(jù),都能根據(jù)算法進(jìn)行問題求解,包保證計(jì)算結(jié)構(gòu)的正確性.(2)有效性 組成算法的每一條指令都必須是能夠被人或機(jī)器確切執(zhí)行的.(3)確定性 算法每執(zhí)行一步之后,對于它的下一步,應(yīng)該有明確的指示.即,保證每一步之后都有關(guān)于下一步動作的指令,不能缺乏下一步指令或僅僅含有模糊不清的指令.(4)有窮性 算法的執(zhí)行必須在有限步內(nèi)結(jié)束.29.C 語言變量的存儲特性可分幾類?(*)自動型(auto)、靜態(tài)型(static)、外部型(extern)和寄存器型(register)。Auto 的特點(diǎn):1.auto 類型標(biāo)識符 變量列表;常常可以缺省 auto。2.函數(shù)內(nèi)定義的局部變量、函數(shù)的形式參數(shù)和函數(shù)體內(nèi)分程序的局部變量。3. 隨函數(shù)的調(diào)用而存在,隨函數(shù)的返回而消失,它們在一次調(diào)用結(jié)束到下一次10調(diào)用開始之間不再占有存

溫馨提示

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

評論

0/150

提交評論