freepeople性欧美熟妇, 色戒完整版无删减158分钟hd, 无码精品国产vα在线观看DVD, 丰满少妇伦精品无码专区在线观看,艾栗栗与纹身男宾馆3p50分钟,国产AV片在线观看,黑人与美女高潮,18岁女RAPPERDISSSUBS,国产手机在机看影片

正文內(nèi)容

c語(yǔ)言面試寶典-全面-展示頁(yè)

2024-10-10 19:13本頁(yè)面
  

【正文】 p),p 為指針得到的是一個(gè) 指針變量的字節(jié)數(shù),而不是p 所指的內(nèi)存容量。 // 注意p 指向常量字符串 p[0] = ‘X’。 a[0] = ‘X’。指針可以隨時(shí)指向任意類型的內(nèi)存塊。 2) 有些集成化的調(diào)試工具可以對(duì)const 常量進(jìn)行調(diào)試,但是不能對(duì)宏常量進(jìn)行調(diào)試。而對(duì)后者只進(jìn)行字符替換,沒(méi)有類型安全檢查,并且在字符替換可能會(huì)產(chǎn)生意料不到的錯(cuò)誤。1) const 常量有數(shù)據(jù)類型,而宏常量沒(méi)有數(shù)據(jù)類型。動(dòng)態(tài)內(nèi)存的生存期由程序員決定,使用非常靈活,但問(wèn)題也最多2請(qǐng)說(shuō)出const與define 相比,有何優(yōu)點(diǎn)?答:Const作用:定義常量、修飾函數(shù)參數(shù)、修飾函數(shù)返回值三個(gè)作用。3) 從堆上分配,亦稱動(dòng)態(tài)內(nèi)存分配。在執(zhí)行函數(shù)時(shí),函數(shù)內(nèi)局部變量的存儲(chǔ)單元都可以在棧上創(chuàng)建,函數(shù)執(zhí)行結(jié)束時(shí)這些存儲(chǔ)單元自動(dòng)被釋放。例如全局變量,static 變量。原來(lái)成員的值就不存在了, 而對(duì)于結(jié)構(gòu)的不同成員賦值是互不影響的2描述內(nèi)存分配方式以及它們的區(qū)別?答:1) 從靜態(tài)存儲(chǔ)區(qū)域分配。2結(jié)構(gòu)與聯(lián)合有和區(qū)別?答:(1). 結(jié)構(gòu)和聯(lián)合都是由多個(gè)不同的數(shù)據(jù)類型成員組成, 但在任何同一時(shí)刻, 聯(lián)合中只存放了一個(gè)被選中的成員(所有成員共用一塊地址空間), 而結(jié)構(gòu)的所有成員都存在(不同成員的存放地址不同)。return a * a。結(jié)果,這段代碼可能返不是你所期望的平方值!正確的代碼如下:long square(volatile int *ptr){int a。return a * b。a = *ptr。3). 這段代碼的有個(gè)惡作劇。盡管這并不很常見(jiàn)。它是const因?yàn)槌绦虿粦?yīng)該試圖去修改它。一個(gè)例子是只讀的狀態(tài)寄存器。3). 下面的函數(shù)有什么錯(cuò)誤:int square(volatile int *ptr){return *ptr * *ptr。1). 一個(gè)參數(shù)既可以是const還可以是volatile嗎?解釋為什么。不懂得volatile內(nèi)容將會(huì)帶來(lái)災(zāi)難。我認(rèn)為這是區(qū)分C程序員和嵌入式系統(tǒng)程序員的最基本的問(wèn)題。精確地說(shuō)就是,優(yōu)化器在用到這個(gè)變量時(shí)必須每次都小心地重新讀取這個(gè)變量的值,而不是使用保存在寄存器里的備份。簡(jiǎn)而言之,這樣可以減少bug的出現(xiàn)2關(guān)鍵字volatile有什么含意 并給出三個(gè)不同的例子。)2). 通過(guò)給優(yōu)化器一些附加的信息,使用關(guān)鍵字const也許能產(chǎn)生更緊湊的代碼。如果你曾花很多時(shí)間清理其它人留下的垃圾,你就會(huì)很快學(xué)會(huì)感謝這點(diǎn)多余的信息。如果應(yīng)試者能正確回答這些問(wèn)題,那么他就給我留下了一個(gè)好印象。第四個(gè)意思a是一個(gè)指向整型數(shù)的常指針(也就是說(shuō),指針指向的整型數(shù)是可以修改的,但指針是不可修改的)。前兩個(gè)的作用是一樣,a是一個(gè)常整型數(shù)。int * const a。int const a。(如果你想知道更詳細(xì)的答案,仔細(xì)讀一下Saks的文章吧。去年Dan Saks已經(jīng)在他的文章里完全概括了const的所有用法,因此ESP(譯者:Embedded Systems Programming),只要能說(shuō)出const意味著“只讀”就可以了。在這種情況下,可以將所有包含文件預(yù)編譯為一個(gè)預(yù)編譯頭。c提供的預(yù)處理功能主要有以下三種:1)宏定義 2)文件包含 3)條件編譯 總是使用不經(jīng)常改動(dòng)的大型代碼體。處理開頭的指令,比如拷貝include包含的文件代碼,define宏定義的替換,條件編譯等,就是為編譯做的預(yù)備工作的階段,主要處理開始的預(yù)編譯指令,預(yù)編譯指令指示了在程序正式編譯前就由編譯器進(jìn)行的操作,可以放在程序中的任何位置。0040106D8B55ECmovedx,dwordptr[ebp14h]004010708A4201moval,byteptr[edx+1]004010738845FCmovbyteptr[ebp4],al第一種在讀取時(shí)直接就把字符串中的元素讀到寄存器cl中,而第二種則要先把指針值讀到edx中,在根據(jù)edx讀取字符,顯然慢了。}對(duì)應(yīng)的匯編代碼10:a=c[1]。a = p[1]。char *p=1234567890。比如:includevoidmain(){char a=1。char *s2=bbbbbbbbbbbbbbbbb。堆中的具體內(nèi)容由程序員安排。當(dāng)本次函數(shù)調(diào)用結(jié)束后,局部變量先出棧,然后是參數(shù),最后棧頂指針指向最開始存的地址,也就是主函數(shù)中的下一條指令,程序由該點(diǎn)繼續(xù)運(yùn)行。(5)堆和棧中的存儲(chǔ)內(nèi)容棧:在函數(shù)調(diào)用時(shí),第一個(gè)進(jìn)棧的是主函數(shù)中后的下一條指令(函數(shù)調(diào)用語(yǔ)句的下一條可執(zhí)行語(yǔ)句)的地址,然后是函數(shù)的各個(gè)參數(shù),在大多數(shù)的C編譯器中,參數(shù)是由右往左入棧的,然后是函數(shù)中的局部變量。堆:是由new分配的內(nèi)存,一般速度比較慢,而且容易產(chǎn)生內(nèi)存碎片,不過(guò)用起來(lái)最方便.另外,在WINDOWS下,最好的方式是用Virtual Alloc分配內(nèi)存,他不是在堆,也不是在棧,而是直接在進(jìn)程的地址空間中保留一塊內(nèi)存,雖然用起來(lái)最不方便。(4)申請(qǐng)效率的比較:棧:由系統(tǒng)自動(dòng)分配,速度較快。堆的大小受限于計(jì)算機(jī)系統(tǒng)中有效的虛擬內(nèi)存。堆:堆是向高地址擴(kuò)展的數(shù)據(jù)結(jié)構(gòu),是不連續(xù)的內(nèi)存區(qū)域。這句話的意思是棧頂?shù)牡刂泛蜅5淖畲笕萘渴窍到y(tǒng)預(yù)先規(guī)定好的,在WINDOWS下,棧的大小是2M(也有的說(shuō)是1M,總之是一個(gè)編譯時(shí)就確定的常數(shù)),如果申請(qǐng)的空間超過(guò)棧的剩余空間時(shí),將提示overflow。另外,由于找到的堆結(jié)點(diǎn)的大小不一定正好等于申請(qǐng)的大小,系統(tǒng)會(huì)自動(dòng)的將多余的那部分重新放入空閑鏈表中。(2)申請(qǐng)后系統(tǒng)的響應(yīng)棧:只要棧的剩余空間大于所申請(qǐng)空間,系統(tǒng)將為程序提供內(nèi)存,否則將報(bào)異常提示棧溢出。在C++中用new運(yùn)算符如p2=(char*)malloc(10)。例如,聲明在函數(shù)中一個(gè)局部變量int b。 //123456\0放在常量區(qū),編譯器可能會(huì)將它與p3所向123456優(yōu)化成一個(gè)地方。 //分配得來(lái)得10和20字節(jié)的區(qū)域就在堆區(qū)。 p1 = (char*)malloc(10)。 //全局(靜態(tài))初始化區(qū) static int c=0; char *p3=123456。 //棧 char s[]=abc。棧 main() char *p1。程序代碼區(qū)—存放函數(shù)體的二進(jìn)制代碼例子程序這是一個(gè)前輩寫的,非常詳細(xì)//文字常量區(qū)—常量字符串就是放在這里的。全局區(qū)(靜態(tài)區(qū))(static)—全局變量和靜態(tài)變量的存儲(chǔ)是放在一塊的,初始化的全局變量和靜態(tài)變量在一塊區(qū)域,未初始化的全局變量和未初始化的靜態(tài)變量在相鄰的另一塊區(qū)域。堆區(qū)(heap)—一般由程序員分配釋放,若程序員不釋放,程序結(jié)束時(shí)可能由OS回收。static局部變量和普通局部變量有什么區(qū)別:static局部變量只被初始化一次,下一次依據(jù)上一次結(jié)果值;static函數(shù)與普通函數(shù)有什么區(qū)別:static函數(shù)在內(nèi)存中只有一份,普通函數(shù)在每個(gè)被調(diào)用中維持一份拷貝1程序的內(nèi)存分配答:一個(gè)由c/C++編譯的程序占用的內(nèi)存分為以下幾個(gè)部分棧區(qū)(stack)—由編譯器自動(dòng)分配釋放,存放函數(shù)的參數(shù)值,局部變量的值等。只在當(dāng)前源文件中使用的函數(shù)應(yīng)該說(shuō)明為內(nèi)部函數(shù)(static),內(nèi)部函數(shù)應(yīng)該在當(dāng)前源文件中說(shuō)明和定義。static函數(shù)與普通函數(shù)作用域不同。從以上分析可以看出, 把局部變量改變?yōu)殪o態(tài)變量后是改變了它的存儲(chǔ)方式即改變了它的生存期。 而靜態(tài)全局變量則限制了其作用域, 即只在定義該變量的源文件內(nèi)有效, 在同一源程序的其它源文件中不能使用它。 這兩者在存儲(chǔ)方式上并無(wú)不同。1statac 全局變量、局部變量、函數(shù)與普通全局變量、局部變量、函數(shù)static全局變量與普通的全局變量有什么區(qū)別?static局部變量和普通局部變量有什么區(qū)別?static函數(shù)與普通函數(shù)有什么區(qū)別?答 、全局變量(外部變量)的說(shuō)明之前再冠以static 就構(gòu)成了靜態(tài)的全局變量。1語(yǔ)句for( ;1 ;)有什么問(wèn)題?它是什么意思?答 、和while(1)相同,無(wú)限循環(huán)。1?為什么?答 、可以,在不同的C文件中以static形式來(lái)聲明同名全局變量。要用全局變量,需要使用::局部變量可以與全局變量同名,在函數(shù)內(nèi)引用這個(gè)變量時(shí),會(huì)用到同名的局部變量,而不會(huì)用到全局變量。堆棧溢出一般是由什么原因?qū)е碌模看?: 冒泡排序算法的時(shí)間復(fù)雜度是什么?答 :O(n^2)什么函數(shù)不能聲明為虛函數(shù)?答:constructor1隊(duì)列和棧有什么區(qū)別?答:隊(duì)列先進(jìn)先出,棧后進(jìn)先出1不能做switch()的參數(shù)類型答 :switch的參數(shù)不能為實(shí)型。全局變量和局部變量在內(nèi)存中是否有區(qū)別?如果有,是什么區(qū)別?答 :全局變量?jī)?chǔ)存在靜態(tài)數(shù)據(jù)區(qū),局部變量在堆棧中。include 與 include 的區(qū)別?答:前者是從Standard 。程序中使用指針,程序的可讀性差;而引用本身就是目標(biāo)變量的別名,對(duì)引用的操作就是對(duì)目標(biāo)變量的操作。3) 不存在指向空值的引用,但是存在指向空值的指針?!耙谩迸c指針的區(qū)別是什么?答 、1) 引用必須被初始化,指針不必。大多數(shù)應(yīng)試者能正確回答第一部分,一部分能正確回答第二部分,同是很少的人能懂得第三部分。3). 在模塊內(nèi),一個(gè)被聲明為靜態(tài)的函數(shù)只可被這一模塊內(nèi)的其它函數(shù)調(diào)用。2). 在模塊內(nèi)(但在函數(shù)體外),一個(gè)被聲明為靜態(tài)的變量可以被模塊內(nèi)所用函數(shù)訪問(wèn),但不能被模塊外其它函數(shù)訪問(wèn)。第一部分:基本概念及其它問(wèn)答題關(guān)鍵字static的作用是什么?這個(gè)簡(jiǎn)單的問(wèn)題很少有人能回答完全。在C語(yǔ)言中,關(guān)鍵字static有三個(gè)明顯的作用:1). 在函數(shù)體,一個(gè)被聲明為靜態(tài)的變量在這一函數(shù)被調(diào)用過(guò)程中維持其值不變。它是一個(gè)本地的全局變量。那就是,這個(gè)函數(shù)被限制在聲明它的模塊的本地范圍內(nèi)使用。這是一個(gè)應(yīng)試者的嚴(yán)重的缺點(diǎn),因?yàn)樗@然不懂得本地化數(shù)據(jù)和代碼范圍的好處和重要性。2) 引用初始化以后不能被改變,指針可以改變所指的對(duì)象。指針通過(guò)某個(gè)指針變量指向一個(gè)對(duì)象后,對(duì)它所指向的變量間接操作。 流操作符和、賦值操作符=的返回值、拷貝構(gòu)造函數(shù)的參數(shù)、賦值操作符=的參數(shù)、其它情況都推薦使用引用.h頭文件中的ifndef/define/endif 的作用?答:防止該頭文件被重復(fù)引用。描述實(shí)時(shí)系統(tǒng)的基本特性答 :在特定時(shí)間內(nèi)完成特定的任務(wù),實(shí)時(shí)性與可靠性。什么是平衡二叉樹?答 :左右子樹都是平衡二叉樹 且左右子樹的深度差值的絕對(duì)值不大于1。1局部變量能否和全局變量重名?答:能,局部會(huì)屏蔽全局。對(duì)于有些編譯器而言,在同一個(gè)函數(shù)內(nèi)可以定義多個(gè)同名的局部變量,比如在兩個(gè)循環(huán)體內(nèi)都定義一個(gè)同名的局部變量,而那個(gè)局部變量的作用域就在那個(gè)循環(huán)體內(nèi)1如何引用一個(gè)已經(jīng)定義過(guò)的全局變量?答 、可以用引用頭文件的方式,也可以用extern關(guān)鍵字,如果用引用頭文件方式來(lái)引用某個(gè)在頭文件中聲明的全局變量,假定你將那個(gè)變量寫錯(cuò)了,那么在編譯期間會(huì)報(bào)錯(cuò),如果你用extern方式引用時(shí),假定你犯了同樣的錯(cuò)誤,那么在編譯期間不會(huì)報(bào)錯(cuò),而在連接期間報(bào)錯(cuò)??梢栽诓煌腃文件中聲明同名的全局變量,前提是其中只能有一個(gè)C文件中對(duì)此變量賦初值,此時(shí)連接不會(huì)出錯(cuò)。1do……while和while……do有什么區(qū)別?答 、前一個(gè)循環(huán)一遍再判斷,后一個(gè)判斷以后再循環(huán)。全局變量本身就是靜態(tài)存儲(chǔ)方式, 靜態(tài)全局變量當(dāng)然也是靜態(tài)存儲(chǔ)方式。這兩者的區(qū)別雖在于非靜態(tài)全局變量的作用域是整個(gè)源程序, 當(dāng)一個(gè)源程序由多個(gè)源文件組成時(shí),非靜態(tài)的全局變量在各個(gè)源文件中都是有效的。由于靜態(tài)全局變量的作用域局限于一個(gè)源文件內(nèi),只能為該源文件內(nèi)的函數(shù)公用, 因此可以避免在其它源文件中引起錯(cuò)誤。把全局變量改變?yōu)殪o態(tài)變量后是改變了它的作用域, 限制了它的使用范圍。僅在本文件。對(duì)于可在當(dāng)前源文件以外使用的函數(shù),應(yīng)該在一個(gè)頭文件中說(shuō)明,要使用這些函數(shù)的源文件要包含這個(gè)頭文件static全局變量與普通的全局變量有什么區(qū)別:static全局變量只初使化一次,防止在其他文件單元中被引用。其操作方式類似于數(shù)據(jù)結(jié)構(gòu)中的棧。注意它與數(shù)據(jù)結(jié)構(gòu)中的堆是兩回事,分配方式倒是類似于鏈表,呵呵。程序結(jié)束后由系統(tǒng)釋放。程序結(jié)束后由系統(tǒng)釋放。 int a=0。 //全局初始化區(qū) //全局未初始化區(qū) { intb。 //棧 char *p2。 //123456\0在常量區(qū),p3在棧上。 p2 = (char*)malloc(20)。 strcpy(p1,123456)。}解釋堆和棧的區(qū)別答:堆(heap)和棧(stack)的區(qū)別(1)申請(qǐng)方式stack:由系統(tǒng)自動(dòng)分配。系統(tǒng)自動(dòng)在棧中為b開辟空間heap:需要程序員自己申請(qǐng),并指明大小,在c中malloc函數(shù)如p1=(char*)malloc(10)。但是注意pp2本身是在棧中的。堆:首先應(yīng)該知道操作系統(tǒng)有一個(gè)記錄空閑內(nèi)存地址的鏈表,當(dāng)系統(tǒng)收到程序的申請(qǐng)時(shí),會(huì)遍歷該鏈表,尋找第一個(gè)空間大于所申請(qǐng)空間的堆結(jié)點(diǎn),然后將該結(jié)點(diǎn)從空閑結(jié)點(diǎn)鏈表中刪除,并將該結(jié)點(diǎn)的空間分配給程序,另外,對(duì)于大多數(shù)系統(tǒng),會(huì)在這塊內(nèi)存空間中的首地址處記錄本次分配的大小,這樣,代碼中的delete語(yǔ)句才能正確的釋放本內(nèi)存空間。(3)申請(qǐng)大小的限制棧:在Windows下,棧是向低地址擴(kuò)展的數(shù)據(jù)結(jié)構(gòu),是一塊連續(xù)的內(nèi)存的區(qū)域。因此,能從棧獲得的空間較小。這是由于系統(tǒng)是用鏈表來(lái)存儲(chǔ)的空閑內(nèi)存地址的,自然是不連續(xù)的,而鏈表的遍歷方向是由低地址向高地址。由此可見(jiàn),堆獲得的空間比較靈活,也比較大。但程序員是無(wú)法控制的。但是速度快,也最靈活。注意
點(diǎn)擊復(fù)制文檔內(nèi)容
公司管理相關(guān)推薦
文庫(kù)吧 www.dybbs8.com
備案圖鄂ICP備17016276號(hào)-1