六月丁香五月婷婷,丁香五月婷婷网,欧美激情网站,日本护士xxxx,禁止18岁天天操夜夜操,18岁禁止1000免费,国产福利无码一区色费

學習啦>創(chuàng)業(yè)指南>職場>筆試題>

程序員面試筆試寶典

時間: 護托1061 分享

  程序員(英文Programmer)是從事程序開發(fā)、維護的專業(yè)人員。一般將程序員分為程序設計人員和程序編碼人員,但兩者的界限并不非常清楚,特別是在中國。下面就由學習啦小編為大家介紹一下程序員面試筆試寶典的文章,歡迎閱讀。

  程序員面試筆試寶典篇1

  1.extern的作用

  自己理解:應該需要區(qū)分extern在C語言中和C++語言中的作用,C語言中extern聲明的函數(shù)和變量可以被該文件外部模塊引用,C++語言中除了該作用還可以聲明extern “C”聲明一段代碼編譯連接的方法為C語言的方法。

  參考:其實extern的百度詞條解釋的很清楚,具體的也是跟我上面自己理解差別不是很大。

  (a) extern是C/C++語言中聲明函數(shù)和全局變量作用范圍(可見性)的關鍵字,該關鍵字告訴編譯器,其聲明的函數(shù)和變量在本模塊或其他模塊中使用(通常,在模塊的頭文件中對本模塊提供給其它模塊引用的函數(shù)和全局變量以關鍵字extern聲明。)

  (b) 被extern “C”修飾的變量和函數(shù)是按照C語言的方式編譯和鏈接的。(C語言不支持函數(shù)重載,所以函數(shù)的C++和C的編譯方式不同,這一句的作用就是實現(xiàn)C++和C及其他語言混合編程)

  2.strstr()函數(shù)的作用

  strstr()函數(shù)的原型一般為extern char * strstr(const char *src , const char *dest) , 其作用就是尋找目標字符串在源字符串中第一次出現(xiàn)的位置。

  3.windows線程優(yōu)先級問題( 進程和線程的區(qū)別和聯(lián)系 )

  我覺得這個概念可能面試、筆試的時候不是很適合,畢竟平臺相關,大多數(shù)公司可能更多的傾向于linux開發(fā),這個問題更換為進程和線程的區(qū)別更好,這個是筆試,面試常見的知識考查。

  (a) 通常一個進程可以包含若干個線程,它們可以利用進程所擁有的資源。進程是系統(tǒng)進行資源分配和調(diào)度的一個獨立單位,線程是進程的一個實體,是CPU調(diào)度和分派的基本單位,它是比進程更小的能獨立運行的基本單位。線程自己基本不擁有系統(tǒng)資源,只擁有一些在運行中必不可少的資源(如程序計數(shù)器,一組寄存器和棧),線程可與同屬于一個進程的其他線程共享進程所擁有的全部資源。

  線程和進程區(qū)別歸納:

  地址空間和其他資源:進程間互相獨立,同一個進程的各線程共享。

  通信:進程間通信IPC,線程間可以直接讀寫進程序數(shù)據(jù)段(如全局變量)來進行通信-需要進行同步和互斥的輔助。

  調(diào)度和切換:線程上下文切換比進程上下文切換快速,高效。

  多線程的OS中,進程不是一個可執(zhí)行的實體。

  4.多方法交換x與y的值

  5.指針的自加與引用

  6.前置++與后置++

  前置++和后置++我覺得一個比較重要的問題是C++中重載兩個操作符的時候如何區(qū)別:區(qū)分前置和后置 函數(shù)的參數(shù)有一個 (函數(shù)重載),后置++有一個(int)參數(shù)。

  7.inline的作用

  inline函數(shù)不像正常函數(shù)在調(diào)用時存在壓棧和call的操作,它會把程序代碼直接嵌入到調(diào)用代碼段中,也就是說使用inline函數(shù)會增大二進制程序的體積,但是會使執(zhí)行速度加快。

  同時,編譯期間可以對參數(shù)進行強類型的檢查,這是inline優(yōu)于宏的一個方面。

  8.二維數(shù)組的表示

  9.ifndef的作用

  條件編譯的語法,一般情況下,源程序中所有的行都參加編譯。但是有時希望對其中一部分內(nèi)容只在滿足一定條件才進行編譯,也就是對一部分內(nèi)容指定編譯的條件,這就是“條件編譯”。有時,希望當滿足某條件時對一組語句進行編譯,而當條件不滿足時則編譯另一組語句。

  10.KMP算法

  字符串匹配的高級算法

  程序員面試筆試寶典篇2

  1.函數(shù)調(diào)用方式

  __cdecl 堆棧由調(diào)用者清除 參數(shù)從右至左的順序壓入堆棧內(nèi)

  __stdcall 堆棧由被調(diào)用者清除 參數(shù)從右至左的順序壓入堆棧內(nèi)

  __fastcall 堆棧由被調(diào)用者清除 部分參數(shù)保存在寄存器中,然后其他的壓入堆棧內(nèi)

  thiscall(非關鍵字) 堆棧由被調(diào)用者清除 參數(shù)壓入堆棧內(nèi),this指針保存在ECX寄存器內(nèi)

  2.重載函數(shù)

  函數(shù)重載是指在同一作用域內(nèi),可以有一組具有相同函數(shù)名,不同參數(shù)列表的函數(shù),這組函數(shù)被稱為重載函數(shù)。不能利用返回類型進行重載!類中函數(shù)const和非const可以進行重載,其實原理是利用this指針的類型是const和非const進行重載,其實原理就是參數(shù)類型不同,const指針orconst引用調(diào)用的為const版本的函數(shù)~更多函數(shù)重載的知識。

  3.構造函數(shù)和析構函數(shù)

  虛擬析構函數(shù)的使用場景是指向父類的指針實則為子類指針,調(diào)用delete的時候使用虛擬析構函數(shù),防止部分內(nèi)存泄露。

  構造函數(shù)不能聲明為虛擬函數(shù),因為對象的虛擬函數(shù)表的指針其實是在構造函數(shù)內(nèi)編譯器添加完成的代碼,所以在構造函數(shù)執(zhí)行之前無法訪問到虛擬函數(shù)表的。

  4.合并兩個有序鏈表

  類似歸并排序,兩個指針歸并即可。

  5.100億條記錄的文本文件,取出重復數(shù)最多的前10條

  類似top k算法,無法全部讀入內(nèi)存的top k算法是利用容量為k的最大堆,達到線性時間的top k算法。

  首先利用hash table預處理每個元素出現(xiàn)的次數(shù),然后利用次數(shù)執(zhí)行top k算法。

  6.設計一個雙向鏈表,并且提供一個可根據(jù)值刪除元素的函數(shù)

  STL中的list底層及為雙鏈表實現(xiàn)。

  7.二叉樹的多種遍歷算法實現(xiàn)

  8.有讀和寫的兩個線程和一個隊列,讀線程從隊列中讀數(shù)據(jù),寫線程往隊列中寫數(shù)據(jù)

  生產(chǎn)者和消費者模型:

  使用信號燈和互斥量。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
semaphore mutex = 1;
semaphore fillCount = 0;
semaphore emptyCount = BUFFER_SIZE;
 
procedure producer() {
    while(true) {
        item = produceItem();
        down(emptyCount);
            down(mutex);
                putItemIntoBuffer(item);
            up(mutex);
        up(fillCount);
    }
}
procedure consumer() {
    while(true) {
        down(fillCount);
            down(mutex);
                item = removeItemFromBuffer();
            up(mutex);
        up(emptyCount);
        consumeItem(item);
    }
}

  不使用信號燈和互斥量。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
volatile unsigned int produceCount, consumeCount;
TokenType buffer[BUFFER_SIZE];
 
void producer(void) {
    while (1) {
        while (produceCount - consumeCount == BUFFER_SIZE)
            sched_yield(); // 緩沖區(qū)滿
 
        buffer[produceCount % BUFFER_SIZE] = produceToken();
        produceCount += 1;
    }
}
 
void consumer(void) {
    while (1) {
        while (produceCount - consumeCount == 0)
           sched_yield(); // 緩沖區(qū)空
 
        consumeToken( buffer[consumeCount % BUFFER_SIZE]);
        consumeCount += 1;
    }
}

  9.stack,heap,memory-pool

  10.TCP的流量控制和擁塞控制機制

  TCP的流量控制就是讓發(fā)送方的發(fā)送速率不要太快,讓接收方來得及接收。利用滑動窗口機制可以很方便的在TCP連接上實現(xiàn)對發(fā)送方的流量控制。TCP的窗口單位是字節(jié),不是報文段,發(fā)送方的發(fā)送窗口不能超過接收方給出的接收窗口的數(shù)值。

  所謂的擁塞控制為防止過多的數(shù)據(jù)注入到網(wǎng)絡中,這樣可以使網(wǎng)絡中的路由器或鏈路不致過載。擁塞控制索要做的都有一個前提,就是網(wǎng)絡能承受現(xiàn)有的網(wǎng)絡負荷。流量控制往往指點對點通信量的控制,是一個端到端的問題。因特網(wǎng)建議標準RFC2581定義了進行擁塞控制的四種算法,即慢開始(Slow-start),擁塞避免(Congestion Avoidance)快重傳(Fast Restrangsmit)和快回復(Fast Recovery)。

  程序員面試筆試寶典篇3

  1.寫一個函數(shù),返回一個字符串中只出現(xiàn)一次的第一個字符

  目前想到的方法就是利用hash表記錄每個字符出現(xiàn)的次數(shù),然后兩次遍歷即可找到只出現(xiàn)一次的第一個字符。

  2.求一個數(shù)組中第k大的數(shù)的位置

  3.面向?qū)ο罄^承,多態(tài)問題,如多態(tài)的實現(xiàn)機制

  虛擬函數(shù),指針and引用

  4.內(nèi)聯(lián)函數(shù)什么時候不展開

  在內(nèi)聯(lián)函數(shù)內(nèi)不允許用循環(huán)語句和開關語句?!∪绻麅?nèi)聯(lián)函數(shù)有這些語句,則編譯將該函數(shù)視同普通函數(shù)那樣產(chǎn)生函數(shù)調(diào)用代碼,遞歸函數(shù)(自己調(diào)用自己的函數(shù))是不能被用來做內(nèi)聯(lián)函數(shù)的。內(nèi)聯(lián)函數(shù)只適合于只有1~5行的小函數(shù)。對一個含有許多語句的大函數(shù),函數(shù)調(diào)用和返回的開銷相對來說微不足道,所以也沒有必要用內(nèi)聯(lián)函數(shù)實現(xiàn)。

  5.成員函數(shù)初始化列表有什么作用?什么必須在成員初始化列表中進行初始化?

  類的static變量在類的構造函數(shù)前已進行初始化!

  類對象的構造順序:

  (a)分配內(nèi)存,調(diào)用構造函數(shù)時,隱式/顯式的初始化各數(shù)據(jù)成員(順序和類中聲明對象一致)。如果無成員初始化列表。隱式初始化階段按照聲明的順序依次調(diào)用所有基類的缺省構造函數(shù),然后所有成員類對象的缺省構造函數(shù)。

  (b)進入構造函數(shù)執(zhí)行函數(shù)體內(nèi)語句,函數(shù)體內(nèi)的數(shù)據(jù)成員的設置被認為賦值,而不是初始化。

  所以,使用初始化列表的兩個情況:

  1)必須使用初始化列表進行初始化![1]數(shù)據(jù)成員為類對象并且該類對象僅提供帶參數(shù)的構造函數(shù)[2]const修飾的數(shù)據(jù)成員[3]引用數(shù)據(jù)成員;

  2)考慮效率的時候!因為未利用初始化列表而是在構造函數(shù)體內(nèi)進行賦值,則調(diào)用了缺省構造函數(shù)和賦值運算符操作。如果數(shù)據(jù)成員為自定義的類對象,則效率比直接利用構造函數(shù)初始化低很多。

  6.指針與引用的區(qū)別

  相同點:

  都是地址的概念;指針指向一塊內(nèi)存,它的內(nèi)容是所指內(nèi)存的地址;而引用則是某塊內(nèi)存的別名。

  不同點:

  指針是一個實體,而引用僅是個別名

  引用只能并且必須在定義時被初始化一次,之后不可變(類似常量指針,引用自帶常量指針屬性);指針可變;

  引用沒有const,指針有const,const的指針不能夠改變;(int & const refer 不存在,因為引用本身就初始化一次不可變,但是const int &refer是存在的,指引用所指向的值不可改變)

  引用不能為空,指針可以為空

  sizeof針對指針得到的是指針的大小,針對引用得到的是指向?qū)ο蟮拇笮?

  指針的++操作和引用的++操作完全不同,指針為移動指針地址,引用++操作作用于指向的對象;

  引用是類型安全的,而指針不是類型安全的。

  7.創(chuàng)建空類時,哪些成員函數(shù)是系統(tǒng)默認的?

  構造函數(shù),拷貝構造,賦值函數(shù),析構函數(shù),取址運算符,const取址運算符

  8.有10W個IP段,這些IP段之間都不重合,隨便給定一個IP,求出屬于哪個IP段

  9.網(wǎng)絡編程(網(wǎng)絡編程范式,非阻塞connect)

  常見的IO模型有阻塞、非阻塞、IO多路復用、異步。

3172086