往年的深信服筆試題(齊全)_第1頁
往年的深信服筆試題(齊全)_第2頁
往年的深信服筆試題(齊全)_第3頁
往年的深信服筆試題(齊全)_第4頁
往年的深信服筆試題(齊全)_第5頁
已閱讀5頁,還剩3頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、· 一,六道選擇題 (可以多選) 1 char   *p   =   "hello   world"   p存儲在()指向 /堆棧  char   p   =   "hello   world"   p存儲在()指向  全局變量  /數(shù)據(jù)段  static變量  /數(shù)據(jù)段  分別在哪個地方?    1數(shù)據(jù)段   2代碼段   3堆   4

2、堆棧  (此題可以配合同文件夾下的char.cpp)(二、例子程序      這是一個前輩寫的,非常詳細      /main.cpp      int   a   =   0;   全局初始化區(qū)      char   *p1;   全局未初始化區(qū)      main()           int   b

3、;   棧      char   s   =   "abc"   棧      char   *p2;   棧      char   *p3   =   "123456"   1234560在常量區(qū),p3在棧上。      static   int   c   =0;   全局(靜態(tài))

4、初始化區(qū)      p1   =   (char   *)malloc(10);      p2   =   (char   *)malloc(20);      分配得來得10和20字節(jié)的區(qū)域就在堆區(qū)。      strcpy(p1,   "123456");   1234560放在常量區(qū),編譯器可能會將它與p3所指向的"123456"  

5、60; 優(yōu)化成一個地方。      不知道是那個高人怎么想的和我一樣,我估計中間應(yīng)該有錯誤)2 % & . &&   <= = 那個優(yōu)先級別最高. & % <= && =34以下哪些通信方式是可靠的通訊方式    1信號2管道3消息4tcp 5udp 6串口I/O  5是(M)?(a+):( a-),此處的M等于 我選CA,M=O,B,M=1,C,M!=O,D,M!=16是Unix的啟動順序排序。(6個選項)二1是數(shù)制轉(zhuǎn)換151轉(zhuǎn)2進制和九進制。10010

6、111 1772已知0的ASCII碼為0x40,那么int   120;在內(nèi)存中的表示形式是0x_  78(0的ASCII碼為0x40,應(yīng)該為0x30)31、在linux下,查看目錄大小的命令是:du sh dirname    2、修改文件屬性的命令是:chomd/chgrp    3、切換為其他用戶身份的命令是:su 4還有一道指針交換數(shù)值 int i=0,j=10,int* p=&i, int* q=&j,int fun (*a,*b)int* temp=a;*a*=10;

7、*b*=10;a=b;b=temp;最后問調(diào)用fun(&p,q)問i、j、p、q的最終值(具體形式大概如此,但中間指針肯定記的錯誤)此題主要考察指針指向一個整數(shù),然后利用指針改變變量,最后交換指針· 5有道填插入排序的算法。有一個數(shù)組a0 到 ai-1為從小到大排序,ai 到acount-1沒有排序,請您添加3條語句使它們按照從小到大排序int insert_sort(int a,int count) for(int i=1;i<count;+i) int j,t; t=ai; (j=i-1;) while(j>=0&&t<aj) (aj+1

8、=aj;) j-; (aj+1=t;) return 0;三,編程與邏輯題1自己寫一個strstr(單鏈表判斷有無環(huán),)char* strstr(char* buf, char* sub)char* bp;char* sp;If(!*sub)return buf;while(*buf)bf=buf;sp=sub;do if(!*sp)return buf;while(*bp+=*sp+)buf+=1;return 0;2遍歷文本找單詞并刪掉出現(xiàn)頻率最少的單詞,fun (char* pText) #include <stdio.h>#include &l

9、t;stdarg.h> /定義av_list、av_start、av_arg等宏· 3實現(xiàn)一個與printf功能相似的函數(shù) #include <iostream>#include <conio.h>#include <stdio.h>#include <stdarg.h> /定義av_list、av_start、av_arg等宏/*此函數(shù)的作用:    實現(xiàn)一個參數(shù)個數(shù)可變的函數(shù),此函數(shù)的功能與printf類似, 

10、0;  但在格式處理上,不如printf豐富    無異常,返回一個true,否則返回falseformat字符串的合法情況如下:    1."%zyk%zyk%",OUTPUT:%zyk%zyk%    2."%dzyk%fzyk%s",OUTPUT:(int)zyk(float)zyk(string)    3."zyk",  

11、60; OUTPUT:zyk非法情況如下:    1."%zyk%"    ERROR:不存在%z格式、%后面必須跟一個格式字符*/bool zykPrintf(const char * format,.)    /定義一個可用于指向參數(shù)的指針(實為char *),    va_list argPtr;    

12、;/把函數(shù)的第一個參數(shù)format的地址傳給argPtr    va_start(argPtr,format);            const int size = strlen(format)+1;    char *tmp = new charsize;    memse

13、t(tmp, 0, size);· while (*format != 0)            int i;        for (i=0; i<size && *format!='%' && *format!

14、=0; i+)                    tmpi=*format+;                tmpi = 0; /在有效的字符串末尾作0值防護   

15、     printf("%s",tmp);        if (*format = 0)            return true;        switch(*+format)  

16、;              /按指定類型讀取下一個參數(shù),并打印        case 'd':  printf("%d", va_arg(argPtr, int); break;        cas

17、e 's':  printf("%s", va_arg(argPtr, char *); break;         case 'c':  printf("%c", va_arg(argPtr, char); break;       

18、 case 'f':  printf("%f", va_arg(argPtr, float); break;                /對%的處理        case '%':  printf(&q

19、uot;%"); break;         /格式錯誤        default :  printf(" Error Ocurr!Please Check the Format!"); return false;      

20、0;         +format;            delete tmp;    return true;int main(int argc,char * argv)    zykPrintf("%zyk"); 

21、;/error    zykPrintf("zyk%"); /error    zykPrintf("%zyk%zyk%"); /OUTPUT: %zyk%zyk%    zykPrintf("nzyk is a pretty boy! His age is %d and %s",5,&q

22、uot;I love zyk_!");                     getch();                     return

23、 0; 文章引用自: · 4是一道邏輯題,有的數(shù)是2,3,5的倍數(shù),在三位數(shù)中出去可整除這三個數(shù)的和 ( 5升和3升桶量4升水) 四,改錯題三道1tozero算法2比較簡單3是高質(zhì)量里的一道題 五,問答題1VC中有哪些方法避免C編程中的頭文件重復(fù)包含:#ifndef !#def !#endif2在C+中extern c的作用(按鍵轉(zhuǎn)換,比如點擊p輸出q)作為extern是C/C+語言中表明函數(shù)和全局變量作用范圍(可見性)的關(guān)鍵字,該關(guān)鍵字告訴編譯器,其聲明的函數(shù)和變量可以在本模塊或其它模塊中使用。extern "C"是連接申明(linkage decla

24、ration),被extern "C"修飾的變量和函數(shù)是按照C語言方式編譯和連接的3編程中異步IO和同步IO有什么區(qū)別?說說你可知道的幾種IO?4使用異步socket編程,通常因為網(wǎng)絡(luò)擁塞send不出數(shù)據(jù),會獲得什么樣的錯誤碼(windows下舉例),通常如何處理這種情況?(核心太與用戶太的區(qū)別,x86如何轉(zhuǎn)換。)5將程序移植到不同的32位cpu中,經(jīng)常出現(xiàn)結(jié)構(gòu)字節(jié)對齊和大小端的問題,有哪能些方法避免?(是子網(wǎng)源碼的判斷,計算,ABCDE網(wǎng)絡(luò)的區(qū)別,DE網(wǎng)絡(luò)的用途,)6怎樣解決在vc中內(nèi)存泄漏的問題(release版本)(1)放置關(guān)鍵字assert()(2)生成map文件。

25、它并不往exe文件中添加任何東西,僅僅只是把編譯連接時的所有函數(shù)入口地址記錄在后綴為.map文件。程序崩潰的時候,可以得到一個崩潰時的EIP地址,通過地址可以很容易的查到崩潰所在的函數(shù)。(在vc setting下有個link按鈕選上generate mapfile)(3)Release版本也是可以設(shè)置斷點的,在希望設(shè)置斷點處加入_asm int 3(4)熟悉匯編,通過編譯時的匯編看出(5)使用第三方調(diào)試器。(6)關(guān)掉發(fā)行版中的一些優(yōu)化選項,生成調(diào)試信息。(是p2p軟件在nat用戶里實現(xiàn)數(shù)據(jù)互傳的原理開發(fā)類筆試全部是C/C+,要求對底層有一定的了解開發(fā)類的筆試題目比較暈,共五頁紙,要求兩個鐘頭完

26、成(我的簡歷沒有通過篩選,我是去霸王筆的-_-)好像考的內(nèi)容都跟網(wǎng)上流傳的差不多,題目內(nèi)容大致如下:希望對參加深信服筆試和面試的同學(xué)有所幫助:) 1.選擇題:6題  第一題是考變量和值的存儲位置(堆/棧/代碼段/數(shù)據(jù)段等)  最后一題是Unix系統(tǒng)的啟動順序,其他幾題比較簡單。 2.填空題:4/5題  考sizeof、指針、數(shù)制轉(zhuǎn)換、排序等,看過高質(zhì)量C/C+應(yīng)該都沒有問題。 3.改錯題:3題  有道題跟高質(zhì)量C/C+中一道指針題類似,不過那題中沒有錯,原本不需要修改,卻反倒被我改錯了,汗.另外兩題比較簡單。 4.編程題: 4/5題  判斷鏈表

27、有沒有環(huán)(要求用兩種方法);  實現(xiàn)C中的printf深圳某公司幾個vc/mfc筆試題目(含參考答案)1:Release版本下如何解決memory leak 以及非法操作的BUG。(搞不清什么非法操作)2: 在異步socket時,為什么有時send不出數(shù)據(jù),會報什么錯誤(分windows/linux下),你一般怎么處理? 下面是幾個編程的3:實現(xiàn)strstr模型 (我暈,我寫了個函數(shù),只是不是strstr,而是strchr)4: 實現(xiàn)printf類似的函數(shù), void myprintf(char *str,.)(用console API嗎?好像在哪書上看到可用那些API實現(xiàn),嘿,我就

28、寫了個std:cout<<)5: 刪除文本文件中出現(xiàn)頻率最小的單詞,(文件里以空格表示間隔一個單詞)void func(char *pTxt)1、strstr的實現(xiàn)原型。char *my_strstr(const char *str, const char *strSearch)while (*str != '0')char *p = (char *)str;char *ps = (char *)strSearch;while ( ps && *p = *ps )p , ps ;if ('0' = *ps)return (char *

29、)str;str ;return NULL;2、從指定文本中刪除出現(xiàn)頻率最少的單詞,如果有多個,則都刪除。實現(xiàn)void func(char* pTxt)函數(shù)。. 看 單詞處理, 論壇中很多都有涉及3、printf的實現(xiàn)。int printf(const char *format, .)va_list arglist;int buffing;int retval;va_start(arglist, format);_ASSERTE(format != NULL);#ifdef _MT_lock_str2(1, stdout);_try #endif /* _MT */buffing = _stb

30、uf(stdout);retval = _output(stdout,format,arglist);_ftbuf(buffing, stdout);#ifdef _MT_finally _unlock_str2(1, stdout);#endif /* _MT */return(retval);4、VC中有哪些方法避免C編譯頭文件重復(fù)。(除了#ifndef/#define/#endif外,就想不出來了)#pragma once5、extern "C"的用法。用于 提供 C 接口, 如使用 C 命名方式 等 .6、異步socket編程中,send不出數(shù)據(jù)的錯誤碼是什么,(舉

31、Linux或Windows為例),你是怎么處理的?非阻塞SOCKET,SEND不出數(shù)據(jù)的原因有2個吧,TCP下連接斷開了和該SOCKET處在阻塞狀態(tài)(也就是說在發(fā)送數(shù)據(jù)中)。UPD發(fā)不出只有TCP后面的情況。處理的辦法就是記錄下該SOCKET的狀態(tài),當(dāng)狀態(tài)為阻塞的時間,放入緩沖,當(dāng)該SOCKET再次可寫時,發(fā)送。7、異步IO和同步IO有什么區(qū)別?舉例說明有幾種(如read)?異步IO當(dāng)函數(shù)返回時不一定就完成了IO操作,而同步IO已經(jīng)完成了。所以異步IO需要有一個事件,當(dāng)IO完成時會設(shè)置此事件,調(diào)用者在事件上等待。8、32位系統(tǒng)中,出現(xiàn)結(jié)構(gòu)字節(jié)對齊的問題和大小端的問題的避免?#pragma pack(4)9、如何查出內(nèi)存泄漏和非法操作的BUG(在Release版本下)?使用map文件1, PostMessage只把消息放入隊列,不管其他程序是否處理都返回,然后繼續(xù)執(zhí)行,這是個異步消息投放函數(shù)。而SendMessage必須等待其他程序處理消息完了之后才返回,繼續(xù)執(zhí)行,這是個同步消息投放函數(shù)。而且,PostMessage的返回值表示PostMessage

溫馨提示

  • 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論