国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
題庫(kù)

1.     C++的類(lèi)和C里面的struct有什么區(qū)別?

struct成員默認(rèn)訪問(wèn)權(quán)限為public,而class成員默認(rèn)訪問(wèn)權(quán)限為private

2.     析構(gòu)函數(shù)和虛函數(shù)的用法和作用

析構(gòu)函數(shù)是在對(duì)象生存期結(jié)束時(shí)自動(dòng)調(diào)用的函數(shù),用來(lái)釋放在構(gòu)造函數(shù)分配的內(nèi)存。(注意一些臨時(shí)對(duì)象在賦值以后生命期結(jié)束,自動(dòng)調(diào)用析構(gòu)函數(shù))

虛函數(shù)是指被關(guān)鍵字virtual說(shuō)明的函數(shù),作用是使用C++語(yǔ)言的多態(tài)特性

 

3.     全局變量和局部變量有什么區(qū)別?是怎么實(shí)現(xiàn)的?操作系統(tǒng)和編譯器是怎么知道的?

1) 全局變量的作用用這個(gè)程序塊,而局部變量作用于當(dāng)前函數(shù)

2) 前者在內(nèi)存中分配在全局?jǐn)?shù)據(jù)區(qū),后者分配在棧區(qū)

3)生命周期不同:全局變量隨主程序創(chuàng)建和創(chuàng)建,隨主程序銷(xiāo)毀而銷(xiāo)毀,局部變量在局部函數(shù)內(nèi)部,甚至局部循環(huán)體等內(nèi)部存在,退出就不存在

4) 使用方式不同:通過(guò)聲明后全局變量程序的各個(gè)部分都可以用到,局部變量只能在局部使用

 

4.     N個(gè)大小不等的自然數(shù)(1--N),請(qǐng)將它們由小到大排序.要求程序算法:時(shí)間復(fù)雜度為O(n),空間復(fù)雜度為O(1)。

void sort(int e[], int n)

{

int i;

int t;

 

for (i=1; i<n+1; i++)

{

  t = e[e[i]];

  e[e[i]] = e[i];

  e[i] = t;

}

}

 

5.     堆與棧的去區(qū)別

A. 申請(qǐng)方式不同

Stack由系統(tǒng)自動(dòng)分配,而heap需要程序員自己申請(qǐng),并指明大小。

B. 申請(qǐng)后系統(tǒng)的響應(yīng)不同

Stack:只要棧的剩余空間大于申請(qǐng)空間,系統(tǒng)就為程序提供內(nèi)存,否則將拋出棧溢出異常

Heap:當(dāng)系統(tǒng)收到程序申請(qǐng)時(shí),先遍歷操作系統(tǒng)中記錄空閑內(nèi)存地址的鏈表,尋找第一個(gè)大于所申請(qǐng)空間的堆結(jié)點(diǎn),然后將該結(jié)點(diǎn)從空間結(jié)點(diǎn)鏈表中刪除,并將該結(jié)點(diǎn)的空間分配給程序。另外,大多數(shù)系統(tǒng)還會(huì)在這塊內(nèi)存空間中的首地址處記錄本次分配的大小,以便于delete語(yǔ)句正確釋放空間。而且,由于找到的堆結(jié)點(diǎn)的大小不一定正好等于申請(qǐng)的大小,系統(tǒng)會(huì)自動(dòng)將多余的那部分重新放入空閑鏈表。

C. 申請(qǐng)大小限制的不同

Stack:在windows下,棧的大小是2M(也可能是1M它是一個(gè)編譯時(shí)就確定的常數(shù)),如果申請(qǐng)的空間超過(guò)棧的剩余空間時(shí),將提示overflow。因此,能從棧獲得的空間較小。

堆:堆是向高地址擴(kuò)展的數(shù)據(jù)結(jié)構(gòu),是不連續(xù)的內(nèi)存區(qū)域。這是由于系統(tǒng)是用鏈表來(lái)存儲(chǔ)的空閑內(nèi)存地址的,自然是不連續(xù)的,而鏈表的遍歷方向是由低地址向高地址。堆的大小受限于計(jì)算機(jī)系統(tǒng)中有效的虛擬內(nèi)存。由此可見(jiàn),堆獲得的空間比較靈活,也比較大。

D. 申請(qǐng)效率的比較:

棧由系統(tǒng)自動(dòng)分配,速度較快。但程序員是無(wú)法控制的。

堆是由new分配的內(nèi)存,一般速度比較慢,而且容易產(chǎn)生內(nèi)存碎片,不過(guò)用起來(lái)最方便。

另外,在WINDOWS下,最好的方式是用VirtualAlloc分配內(nèi)存,他不是在堆,也不是在棧是直接在進(jìn)程的地址空間中保留一快內(nèi)存,雖然用起來(lái)最不方便。但是速度快,也最靈活。

E. 堆和棧中的存儲(chǔ)內(nèi)容

棧:在函數(shù)調(diào)用時(shí),第一個(gè)進(jìn)棧的是主函數(shù)中后的下一條指令(函數(shù)調(diào)用語(yǔ)句的下一條可執(zhí)行語(yǔ)句)的地址,然后是函數(shù)的各個(gè)參數(shù),在大多數(shù)的C編譯器中,參數(shù)是由右往左入棧的,然后是函數(shù)中的局部變量。注意靜態(tài)變量是不入棧的。

當(dāng)本次函數(shù)調(diào)用結(jié)束后,局部變量先出棧,然后是參數(shù),最后棧頂指針指向最開(kāi)始存的地址,也就是主函數(shù)中的下一條指令,程序由該點(diǎn)繼續(xù)運(yùn)行。

堆:一般是在堆的頭部用一個(gè)字節(jié)存放堆的大小。堆中的具體內(nèi)容有程序員安排。

 

6.     含參數(shù)的宏與函數(shù)的優(yōu)缺點(diǎn)

宏:優(yōu)點(diǎn):在預(yù)處理階段完成,不占用編譯時(shí)間,同時(shí),省去了函數(shù)調(diào)用的開(kāi)銷(xiāo),運(yùn)行效率高;缺點(diǎn):不進(jìn)行類(lèi)型檢查,多次宏替換會(huì)導(dǎo)致代碼體積變大,而且由于宏本質(zhì)上是字符串替換,故可能會(huì)由于一些參數(shù)的副作用導(dǎo)致得出錯(cuò)誤的結(jié)果。

函數(shù):優(yōu)點(diǎn):沒(méi)有帶參數(shù)宏可能導(dǎo)致的副作用,進(jìn)行類(lèi)型檢查,計(jì)算的正確性更有保證;缺點(diǎn):函數(shù)調(diào)用需要參數(shù)、返回地址等的入棧、出棧開(kāi)銷(xiāo),效率沒(méi)有帶參數(shù)宏高

PS:宏與內(nèi)聯(lián)函數(shù)的區(qū)別

內(nèi)聯(lián)函數(shù)和宏都是在程序出現(xiàn)的地方展開(kāi),內(nèi)聯(lián)函數(shù)不是通過(guò)函數(shù)調(diào)用實(shí)現(xiàn)的,是在調(diào)用該函數(shù)的程序處將它展開(kāi)(在編譯期間完成的),宏同樣是;   

不同的是:內(nèi)聯(lián)函數(shù)可以在編譯期間完成諸如類(lèi)型檢測(cè),語(yǔ)句是否正確等編譯功能;宏就不具有這樣的功能,而且宏展開(kāi)的時(shí)間和內(nèi)聯(lián)函數(shù)也是不同的(在運(yùn)行期間展開(kāi))

 

7.     Windows程序的入口是哪里?寫(xiě)出Windows消息機(jī)制的流程

Windows程序的入口是WinMain()函數(shù)

 

       

Windows應(yīng)用程序消息處理機(jī)制:

A. 操作系統(tǒng)接收應(yīng)用程序的窗口消息,將消息投遞到該應(yīng)用程序的消息隊(duì)列中

B. 應(yīng)用程序在消息循環(huán)中調(diào)用GetMessage函數(shù)從消息隊(duì)列中取出一條一條的消息,取出消息后,應(yīng)用程序可以對(duì)消息進(jìn)行一些預(yù)處理。

C. 應(yīng)用程序調(diào)用DispatchMessage,將消息回傳給操作系統(tǒng)。

D. 系統(tǒng)利用WNDCLASS結(jié)構(gòu)體的lpfnWndProc成員保存的窗口過(guò)程函數(shù)的指針調(diào)用窗口過(guò)程,對(duì)消息進(jìn)行處理。

8.     如何定義和實(shí)現(xiàn)一個(gè)類(lèi)的成員函數(shù)為回調(diào)函數(shù)

A.     什么是回調(diào)函數(shù)?

簡(jiǎn)而言之,回調(diào)函數(shù)就是被調(diào)用者回頭調(diào)用調(diào)用者的函數(shù)。

使用回調(diào)函數(shù)實(shí)際上就是在調(diào)用某個(gè)函數(shù)(通常是API函數(shù))時(shí),將自己的一個(gè)函數(shù)(這個(gè)函數(shù)為回調(diào)函數(shù))的地址作為參數(shù)傳遞給那個(gè)被調(diào)用函數(shù)。而該被調(diào)用函數(shù)在需要的時(shí)候,利用傳遞的地址調(diào)用回調(diào)函數(shù)。

B.      如何定義和實(shí)現(xiàn)一個(gè)類(lèi)的成員函數(shù)為回調(diào)函數(shù):

a.   聲明;b.   定義;c.    設(shè)置觸發(fā)條件(在你的函數(shù)中把你的回調(diào)函數(shù)名作為一個(gè)參數(shù),以便系統(tǒng)調(diào)用)

如:

一、聲明回調(diào)函數(shù)類(lèi)型

typedef void (*FunPtr)(void);

二、定義回調(diào)函數(shù)

class A  

{

public:

       A();

       static void callBackFun(void)   //回調(diào)函數(shù),必須聲明為static

       {

              cout<<"callBackFun"<<endl;

       }

       virtual ~A();

 

};

三、設(shè)置觸發(fā)條件

void Funtype(FunPtr p)

{

       p();

}

void main(void)

{

       Funtype(A::callBackFun);

}

C.     回調(diào)函數(shù)與API函數(shù)

回調(diào)和API非常接近,他們的共性都是跨層調(diào)用的函數(shù)。但區(qū)別是API是低層提供給高層的調(diào)用,一般這個(gè)函數(shù)對(duì)高層都是已知的;而回調(diào)正好相反,他是高層提供給底層的調(diào)用,對(duì)于低層他是未知的,必須由高層進(jìn)行安裝,這個(gè)安裝函數(shù)其實(shí)就是一個(gè)低層提供的API,安裝后低層不知道這個(gè)回調(diào)的名字,但它通過(guò)一個(gè)函數(shù)指針來(lái)保存這個(gè)回調(diào)函數(shù),在需要調(diào)用時(shí),只需引用這個(gè)函數(shù)指針和相關(guān)的參數(shù)指針。

其實(shí):回調(diào)就是該函數(shù)寫(xiě)在高層,低層通過(guò)一個(gè)函數(shù)指針保存這個(gè)函數(shù),在某個(gè)事件的觸發(fā)下,低層通過(guò)該函數(shù)指針調(diào)用高層那個(gè)函數(shù)。

 

 

 

 

9.CPU在上電后,進(jìn)入操作系統(tǒng)的main()之前必須做什么工作?


BIOS:(基本輸入輸出系統(tǒng),主要任務(wù)是提供CPU所需的啟動(dòng)命令。)計(jì)算機(jī)進(jìn)入復(fù)位狀態(tài)后,內(nèi)存被自動(dòng)清零。有預(yù)先編好了供系統(tǒng)啟動(dòng)使用的啟動(dòng)程序存放在ROM的固定位置FFFF:0000中,CPU就從BIOS獲得了啟動(dòng)所需的指令集,該指令集除了完成硬件的啟動(dòng)外,還要將硬盤(pán)上有關(guān)啟動(dòng)的系統(tǒng)軟件調(diào)入內(nèi)存。

bios中啟動(dòng)程序的主要任務(wù)如下:

1.上電自檢。

2.對(duì)系統(tǒng)內(nèi)的硬件設(shè)。進(jìn)行監(jiān)測(cè)和連接,并把測(cè)試所得的數(shù)據(jù)存放到bios數(shù)據(jù)區(qū)。

3.從軟盤(pán)或者磁盤(pán)上讀入Boot Loader,從而將系統(tǒng)啟動(dòng)代碼讀入內(nèi)存。

過(guò)程如下: [!21ki@][@21ki!]
bios啟動(dòng)自檢

讀取MBR [!21ki@][@21ki!]OS
轉(zhuǎn)到MBR執(zhí)行它的代碼,它會(huì)檢測(cè)活動(dòng)分區(qū) [!21ki@][@21ki!]
把活動(dòng)分區(qū)的引導(dǎo)扇區(qū)的引導(dǎo)代碼裝入內(nèi)存 [!21ki@][@21ki!]
運(yùn)行引導(dǎo)代碼 [!21ki@][@21ki!]
引導(dǎo)代碼裝入該分區(qū)的操作系統(tǒng) [!21ki@][@21ki!]
也就是進(jìn)入main()(當(dāng)然不一定叫main,如linux下叫start_kernel)執(zhí)行一系列的初始化,然后最終啟動(dòng)登錄界面
i!]
實(shí)現(xiàn)啟動(dòng)過(guò)程

MBR是英文Master Boot Record的縮寫(xiě),中文意為主引導(dǎo)記錄。硬盤(pán)的0磁道的第一個(gè)扇區(qū)稱(chēng)為MBR,它的大小是512字節(jié),而這個(gè)區(qū)域可以分為兩個(gè)部分。第一部分為pre-boot區(qū)(預(yù)啟動(dòng)區(qū)),占446字節(jié);第二部分是Partition table區(qū)(分區(qū)表),占66個(gè)字節(jié),該區(qū)相當(dāng)于一個(gè)小程序,作用是判斷哪個(gè)分區(qū)被標(biāo)記為活動(dòng)分區(qū),然后去讀取那個(gè)分區(qū)的啟動(dòng)區(qū),并運(yùn)行該區(qū)中的代碼。
-----------------------------

bios自舉:檢查硬件等
讀取MBR
轉(zhuǎn)到MBR執(zhí)行它的代碼,它會(huì)檢測(cè)活動(dòng)分區(qū)
把活動(dòng)分區(qū)的引導(dǎo)扇區(qū)的引導(dǎo)代碼裝入內(nèi)存
運(yùn)行引導(dǎo)代碼
引導(dǎo)代碼裝入該分區(qū)的操作系統(tǒng)
也就是進(jìn)入main()(當(dāng)然不一定叫main,如linux下叫start_kernel)執(zhí)行一系列的初始化,然后最終啟動(dòng)登錄界面
實(shí)現(xiàn)啟動(dòng)過(guò)程

------------------------------
10手機(jī)用戶在從一個(gè)基站漫游到另一個(gè)基站的過(guò)程中,都會(huì)發(fā)生什么?

在退出當(dāng)前基站前,在下一個(gè)基站注冊(cè),當(dāng)注冊(cè)完畢開(kāi)啟新的信道后,從上一個(gè)基站退出!

11.存儲(chǔ)過(guò)程和函數(shù)的區(qū)別是什么?

存儲(chǔ)過(guò)程是用戶定義的一些列sql語(yǔ)句的集合,涉及特定表或者其他對(duì)象的任務(wù),用戶可以調(diào)用存儲(chǔ)過(guò)程。函數(shù)通常是數(shù)據(jù)庫(kù)已經(jīng)定義的方法,它接收參數(shù)并返回某種類(lèi)型的值,并且不涉及特定用戶表。

12.游標(biāo)的作用是什么?

游標(biāo)用于定位結(jié)果集的行。通過(guò)判斷全局變量@@FETCH_STATUS的值可以判斷其是否到了最后。通常此變量不等于0表示出錯(cuò)或者到了最后。

13.什么叫sql注入式攻擊?如何防范?

就是攻擊者把sql命令插入到Web表單的輸入域或者頁(yè)面請(qǐng)求的查詢字符串中,欺騙服務(wù)器執(zhí)行惡意的sql命令。在某些表單中,用戶輸入的內(nèi)容直接用來(lái)構(gòu)造動(dòng)態(tài)sql命令,或作為存儲(chǔ)過(guò)程的參數(shù),這類(lèi)表單特別容易收到sql注入式攻擊。防范方法:在利用表單輸入的內(nèi)容構(gòu)造sql命令之前,把所有輸入內(nèi)容都過(guò)濾一番。如:替換單引號(hào)(把所有單獨(dú)出現(xiàn)的單引號(hào)改成兩個(gè)單引號(hào),防止攻擊者修改sql命令的含義),刪除用戶輸入內(nèi)容中的所有連字符(防止攻擊者順利獲得訪問(wèn)權(quán)限),對(duì)于用來(lái)執(zhí)行查詢的數(shù)據(jù)庫(kù)賬戶,限制其權(quán)限(隔離不同賬戶的可用操作),用存儲(chǔ)過(guò)程來(lái)執(zhí)行所有的查詢。檢查用戶輸入的合法性,將用戶登錄名稱(chēng)、密碼等數(shù)據(jù)加密保存,檢查提取數(shù)據(jù)的查詢所返回的記錄數(shù)量。

14.庫(kù)函數(shù)調(diào)用和系統(tǒng)函數(shù)調(diào)用的區(qū)別?

   簡(jiǎn)明的回答是庫(kù)函數(shù)調(diào)用是語(yǔ)言或應(yīng)用程序的一部分,而系統(tǒng)調(diào)用是操作系統(tǒng)的一部分。系統(tǒng)調(diào)用是在操作系統(tǒng)內(nèi)核發(fā)現(xiàn)一個(gè)“trap”或中斷后進(jìn)行的。

庫(kù)函數(shù)調(diào)用:在所有ANSI C編譯器版本中,C函數(shù)庫(kù)是相同的;它調(diào)用函數(shù)庫(kù)中的一個(gè)程序;于用戶程序相聯(lián)系;在用戶地址空間執(zhí)行;運(yùn)行時(shí)間屬于用戶時(shí)間;屬于過(guò)程調(diào)用,開(kāi)銷(xiāo)較?。辉?font face="Times New Roman">libc中大約有300個(gè)程序;典型庫(kù)函數(shù)調(diào)用:System,fprintf,malloc

       系統(tǒng)調(diào)用:各個(gè)操作系統(tǒng)的系統(tǒng)調(diào)用是不同的;他調(diào)用系統(tǒng)內(nèi)核的服務(wù),是操作系統(tǒng)的一個(gè)進(jìn)入點(diǎn),在內(nèi)核地址空間執(zhí)行,它的運(yùn)行時(shí)間屬于系統(tǒng)時(shí)間,需要在切換到內(nèi)核上下文環(huán)境后切換回來(lái),開(kāi)銷(xiāo)較大,在unix中大約有90個(gè)調(diào)用(MS-DOS中少一些),典型系統(tǒng)調(diào)用:chdir,fork,write,brk。

1。庫(kù)函數(shù)調(diào)用屬于過(guò)程調(diào)用,開(kāi)銷(xiāo)較?。幌到y(tǒng)調(diào)用需要在切換到內(nèi)核上下文環(huán)境然后切換回來(lái),開(kāi)銷(xiāo)大。

2。庫(kù)函數(shù)在用戶空間執(zhí)行;系統(tǒng)調(diào)用在內(nèi)核地址執(zhí)行;

純粹從性能上考慮,應(yīng)該盡量減少使用系統(tǒng)調(diào)用的數(shù)量。但是,許多C函數(shù)庫(kù)中的程序通過(guò)系統(tǒng)調(diào)用來(lái)實(shí)現(xiàn)功能的。


     
15.主程序與子程序間的參數(shù)傳遞三種方式:存儲(chǔ)器傳遞、寄存器傳遞和堆棧傳遞
 

注:4.2 主程序與子程序間的參數(shù)傳遞
4.2.1 利用寄存器傳遞參數(shù)
4.2.2 利用約定存儲(chǔ)單元傳遞參數(shù)
4.2.3 利用堆棧傳遞參數(shù)
4.2.4 利用CALL后續(xù)區(qū)傳遞參數(shù)

16.文件描述符與文件指針有何不同?

       文件描述符就是開(kāi)放文件的每個(gè)進(jìn)程表的一個(gè)偏移量。他用于unix系統(tǒng)調(diào)用中,用于標(biāo)示文件。      FILE指針保存了一個(gè)FILE結(jié)構(gòu)的地址。FILE結(jié)構(gòu)用于表示開(kāi)放的I/O流。它用于ANSI C標(biāo)準(zhǔn)I/O庫(kù)調(diào)用中,用于標(biāo)識(shí)文件。

17.什么是中斷?中斷發(fā)生時(shí)CPU做什么工作?

 

中斷是指計(jì)算機(jī)中出現(xiàn)事件(硬件異?;蚬收?、程序中斷指令、I/O外設(shè)請(qǐng)求)使得CPU暫停當(dāng)前處理的程序,轉(zhuǎn)而執(zhí)行針對(duì)異步事件預(yù)設(shè)的響應(yīng)程序---中斷處理程序。中斷處理程序執(zhí)行完成,CPU恢復(fù)原程序執(zhí)行上下文,繼續(xù)原程序的執(zhí)行。

為了更好保證計(jì)算機(jī)系統(tǒng)的實(shí)時(shí)性,一般的操作系統(tǒng)將中斷處理程序分為兩部分,上半部分和底半部分。系統(tǒng)響應(yīng)上半部分時(shí)不允許中斷的嵌套,因此在執(zhí)行中斷處理程序之前CPU需關(guān)中斷,然后在中斷程序的內(nèi)核堆棧中(中斷發(fā)生的當(dāng)前進(jìn)程使用的系統(tǒng)堆棧)保存用戶堆棧指針、用戶空間返回地址、各相關(guān)寄存器的內(nèi)容。然后開(kāi)中斷,執(zhí)行底半部分。

http://shichen515.blog.sohu.com/68024969.html

18.什么是makefile?

Makefile是指導(dǎo)編譯器編譯源代碼的配置文件。makefile定義了一系列的規(guī)則來(lái)指定,哪些文件需要先編譯,哪些文件需要后編譯,哪些文件需要重新編譯。

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
堆和棧_stm32 walkdream.com
內(nèi)存中的堆與棧
[收集] 經(jīng)典C/C++面試題(五)
局部變量、全局變量、堆、堆棧、靜態(tài)和全局
電腦包屎是什么鬼,UEIF又是什么
電腦故障排除基本知識(shí)200問(wèn)
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服