日韩在线免费播放-日韩在线免费av-日韩在线免费-日韩在线毛片-国产高清不卡视频-国产高清不卡

當前位置:首頁 > 嵌入式培訓 > 嵌入式招聘 > 嵌入式面試題 > 各大軟件公司c++面試題集合,找工作人的福利

各大軟件公司c++面試題集合,找工作人的福利 時間:2018-08-02      來源:未知

對于很多找工作的人來說,面試是找工作的最重要的一個環(huán)節(jié),很多人都毀在了面試題上,今天在這里我總結了個大公司的面試題,都是我去面試時做的和我朋友做的,我都搜集整理出來,希望可以幫到你。

1. 引用與指針有什么區(qū)別?

1) 引用必須被初始化,指針不必。

2) 引用初始化以后不能被改變,指針可以改變所指的對象。

2) 不存在指向空值的引用,但是存在指向空值的指針。

2. 描述實時系統(tǒng)的基本特性

在特定時間內(nèi)完成特定的任務,實時性與可靠性

3. 全局變量和局部變量在內(nèi)存中是否有區(qū)別?如果有,是什么區(qū)別?

全局變量儲存在靜態(tài)數(shù)據(jù)庫,局部變量在堆棧

4. 什么是平衡二叉樹?

左右子樹都是平衡二叉樹 且左右子樹的深度差值的絕對值不大于1

5. 堆棧溢出一般是由什么原因?qū)е碌?

沒有回收垃圾資源。

6. 什么函數(shù)不能聲明為虛函數(shù)

構造函數(shù),友元函數(shù)

7. 冒泡排序算法的時間復雜度是什么?

O(n^2)

8. 寫出float x 與“零值”比較的if語句。

if(x〈0.000001&&x〉-0.000001)

9. Internet采用哪種網(wǎng)絡協(xié)議?該協(xié)議的主要層次結構?

tcp/ip 應用層/傳輸層/網(wǎng)絡層/數(shù)據(jù)鏈路層/物理層

10. Internet物理地址和IP地址轉換采用什么協(xié)議?

ARP (Address Resolution Protocol)(地址解析協(xié)議)

11.IP地址的編碼分為哪倆部分?

IP地址由兩部分組成,網(wǎng)絡號和主機號。不過是要和“子網(wǎng)掩碼”按位與上之后才能區(qū)分哪些是網(wǎng)絡位哪些是主機位。

????月色夫環(huán)寫一下2.用戶輸入M,N值,從1至N開始順序循環(huán)數(shù)數(shù),每數(shù)到M輸出該數(shù)值,直至全部輸出。寫出C程序。

循環(huán)鏈表,用取余操作做

12.不能做switch()的參數(shù)類型是:

switch的參數(shù)不能為實型。

===========================================================================

華為

1、局部變量能否和全局變量重名?

答:能,局部會屏蔽全局。要用全局變量,需要使用"::"

局部變量可以與全局變量同名,在函數(shù)內(nèi)引用這個變量時,會用到同名的局部變量,而不會用到全局變量。對于有些編譯器而言,在同一個函數(shù)內(nèi)可以定義多個同名的局部變量,比如在兩個循環(huán)體內(nèi)都定義一個同名的局部變量,而那個局部變量的作用域就在那個循環(huán)體內(nèi)

?2、如何引用一個已經(jīng)定義過的全局變量?

答:extern可以用引用頭文件的方式,也可以用extern關鍵字,如果用引用頭文件方式來引用某個在頭文件中聲明的全局變理,假定你將那個變寫錯了,那么在編譯期間會報錯,如果你用extern方式引用時,假定你犯了同樣的錯誤,那么在編譯期間不會報錯,而在連接期間報錯

3、全局變量可不可以定義在可被多個.C文件包含的頭文件中?為什么?

答:可以,在不同的C文件中以static形式來聲明同名全局變量。

可以在不同的C文件中聲明同名的全局變量,前提是其中只能有一個C文件中對此變量賦初值,此時連接不會出錯

4、語句for( ;1 ;)有什么問題?它是什么意思?

答:和while(1)相同。

5、do……while和while……do有什么區(qū)別?

答:前一個循環(huán)一遍再判斷,后一個判斷以后再循環(huán)

6、請寫出下列代碼的輸出內(nèi)容

#i nclude

main()

{

int a,b,c,d;

a=10;

b=a++;

c=++a;

d=10*a++;

printf("b,c,d:%d,%d,%d",b,c,d);

return 0;

}

答:10,12,120

??1、static全局變量與普通的全局變量有什么區(qū)別?static局部變量和普通局部變量有什么區(qū)別?static函數(shù)與普通函數(shù)有什么區(qū)別?

全局變量(外部變量)的說明之前再冠以static 就構成了靜態(tài)的全局變量。全局變量本身就是靜態(tài)存儲方式, 靜態(tài)全局變量當然也是靜態(tài)存儲方式。 這兩者在存儲方式上并無不同。這兩者的區(qū)別雖在于非靜態(tài)全局變量的作用域是整個源程序, 當一個源程序由多個源文件組成時,非靜態(tài)的全局變量在各個源文件中都是有效的。 而靜態(tài)全局變量則限制了其作用域, 即只在定義該變量的源文件內(nèi)有效, 在同一源程序的其它源文件中不能使用它。由于靜態(tài)全局變量的作用域局限于一個源文件內(nèi),只能為該源文件內(nèi)的函數(shù)公用, 因此可以避免在其它源文件中引起錯誤。

從以上分析可以看出, 把局部變量改變?yōu)殪o態(tài)變量后是改變了它的存儲方式即改變了它的生存期。把全局變量改變?yōu)殪o態(tài)變量后是改變了它的作用域, 限制了它的使用范圍。

static函數(shù)與普通函數(shù)作用域不同。僅在本文件。只在當前源文件中使用的函數(shù)應該說明為內(nèi)部函數(shù)(static),內(nèi)部函數(shù)應該在當前源文件中說明和定義。對于可在當前源文件以外使用的函數(shù),應該在一個頭文件中說明,要使用這些函數(shù)的源文件要包含這個頭文件

?static全局變量與普通的全局變量有什么區(qū)別:static全局變量只初使化一次,防止在其他文件單元中被引用;

static局部變量和普通局部變量有什么區(qū)別:static局部變量只被初始化一次,下一次依據(jù)上一次結果值;

static函數(shù)與普通函數(shù)有什么區(qū)別:static函數(shù)在內(nèi)存中只有一份,普通函數(shù)在每個被調(diào)用中維持一份拷貝

2、程序的局部變量存在于(堆棧)中,全局變量存在于(靜態(tài)區(qū) )中,動態(tài)申請數(shù)據(jù)存在于( 堆)中。

3、設有以下說明和定義:

typedef union {long i; int k[5]; char c;} DATE;

struct data { int cat; DATE cow; double dog;} too;

DATE max;

則語句 printf("%d",sizeof(struct date)+sizeof(max));的執(zhí)行結果是:___52____

答:DATE是一個union, 變量公用空間. 里面最大的變量類型是int[5], 占用20個字節(jié). 所以它的大小是20

data是一個struct, 每個變量分開占用空間. 依次為int4 + DATE20 + double8 = 32.

所以結果是 20 + 32 = 52.

當然...在某些16位編輯器下, int可能是2字節(jié),那么結果是 int2 + DATE10 + double8 = 20

4、隊列和棧有什么區(qū)別?

隊列先進先出,棧后進先出

5、寫出下列代碼的輸出內(nèi)容

#i nclude

int inc(int a)

{

return(++a);

}

int multi(int*a,int*b,int*c)

{

return(*c=*a**b);

}

typedef int(FUNC1)(int in);

typedef int(FUNC2) (int*,int*,int*);

void show(FUNC2 fun,int arg1, int*arg2)

{

INCp=&inc;

int temp =p(arg1);

fun(&temp,&arg1, arg2);

printf("%d\n",*arg2);

}

main()

{

int a;

show(multi,10,&a);

return 0;

}

答:110

7、請找出下面代碼中的所以錯誤

說明:以下代碼是把一個字符串倒序,如“abcd”倒序后變?yōu)?ldquo;dcba”

1、#i nclude"string.h"

2、main()

3、{

4、 char*src="hello,world";

5、 char* dest=NULL;

6、 int len=strlen(src);

7、 dest=(char*)malloc(len);

8、 char* d=dest;

9、 char* s=src[len];

10、 while(len--!=0)

11、 d++=s--;

12、 printf("%s",dest);

13、 return 0;

14、}

答:

方法1:

int main(){

char* src = "hello,world";

int len = strlen(src);

char* dest = (char*)malloc(len+1);//要為\0分配一個空間

char* d = dest;

char* s = &src[len-1];//指向最后一個字符

while( len-- != 0 )

*d++=*s--;

*d = 0;//尾部要加\0

printf("%s\n",dest);

free(dest);// 使用完,應當釋放空間,以免造成內(nèi)存匯泄露

return 0;

}

方法2:

#i nclude

#i nclude

main()

{

char str[]="hello,world";

int len=strlen(str);

char t;

for(int i=0; i

{

t=str[i];

str[i]=str[len-i-1];

str[len-i-1]=t;

}

printf("%s",str);

return 0;

}

1.-1,2,7,28,,126請問28和126中間那個數(shù)是什么?為什么?

第一題的答案應該是4^3-1=63

規(guī)律是n^3-1(當n為偶數(shù)0,2,4)

n^3+1(當n為奇數(shù)1,3,5)

答案:63

2.用兩個棧實現(xiàn)一個隊列的功能?要求給出算法和思路!

設2個棧為A,B, 一開始均為空.

入隊:

將新元素push入棧A;

出隊:

(1)判斷棧B是否為空;

(2)如果不為空,則將棧A中所有元素依次pop出并push到棧B;

(3)將棧B的棧頂元素pop出;

這樣實現(xiàn)的隊列入隊和出隊的平攤復雜度都還是O(1), 比上面的幾種方法要好。3.在c語言庫函數(shù)中將一個字符轉換成整型的函數(shù)是atool()嗎,這個函數(shù)的原型是什么?

函數(shù)名: atol

功 能: 把字符串轉換成長整型數(shù)

用 法: long atol(const char *nptr);

程序例:

#i nclude

#i nclude

int main(void)

{

long l;

char *str = "98765432";

l = atol(lstr);

printf("string = %s integer = %ld\n", str, l);

return(0);

}

2.對于一個頻繁使用的短小函數(shù),在C語言中應用什么實現(xiàn),在C++中應用什么實現(xiàn)?

c用宏定義,c++用inline

3.直接鏈接兩個信令點的一組鏈路稱作什么?

PPP點到點連接

4.接入網(wǎng)用的是什么接口?

5.voip都用了那些協(xié)議?

6.軟件測試都有那些種類?

黑盒:針對系統(tǒng)功能的測試 白合:測試函數(shù)功能,各函數(shù)接口

7.確定模塊的功能和模塊的接口是在軟件設計的那個隊段完成的?

概要設計階段

8.enum string

{

x1,

x2,

x3=10,

x4,

x5,

}x;

問x= 0x801005,0x8010f4 ;

9.unsigned char *p1;

unsigned long *p2;

p1=(unsigned char *)0x801000;

p2=(unsigned long *)0x810000;

請問p1+5= ;

p2+5= ;

三.選擇題:

1.Ethternet鏈接到Internet用到以下那個協(xié)議?

A.HDLC;B.ARP;C.UDP;D.TCP;E.ID

2.屬于網(wǎng)絡層協(xié)議的是:

A.TCP;B.IP;C.ICMP;D.X.25

3.Windows消息調(diào)度機制是:

A.指令隊列;B.指令堆棧;C.消息隊列;D.消息堆棧;

4.unsigned short hash(unsigned short key)

{

return (key>>)%256

}

請問hash(16),hash(256)的值分別是:

A.1.16;B.8.32;C.4.16;D.1.32

四.找錯題:

1.請問下面程序有什么錯誤?

int a[60][250][1000],i,j,k;

for(k=0;k<=1000;k++)

for(j=0;j<250;j++)

for(i=0;i<60;i++)

a[i][j][k]=0;

把循環(huán)語句內(nèi)外換一下

2.#define Max_CB 500

void LmiQueryCSmd(Struct MSgCB * pmsg)

{

unsigned char ucCmdNum;

......

for(ucCmdNum=0;ucCmdNum

{

......;

}

死循環(huán)

3.以下是求一個數(shù)的平方的程序,請找出錯誤:

#define SQUARE(a)((a)*(a))

int a=5;

int b;

b=SQUARE(a++);

4.typedef unsigned char BYTE

int examply_fun(BYTE gt_len; BYTE *gt_code)

{

BYTE *gt_buf;

gt_buf=(BYTE *)MALLOC(Max_GT_Length);

......

if(gt_len>Max_GT_Length)

{

return GT_Length_ERROR;

}

.......

}

五.問答題:

1.IP Phone的原理是什么?

IPV6

2.TCP/IP通信建立的過程怎樣,端口有什么作用?

三次握手,確定是哪個應用程序使用該協(xié)議

3.1號信令和7號信令有什么區(qū)別,我國某前廣泛使用的是那一種?

4.列舉5種以上的電話新業(yè)務?

高級題

6、已知一個單向鏈表的頭,請寫出刪除其某一個結點的算法,要求,先找到此結點,然后刪除。

slnodetype *Delete(slnodetype *Head,int key){}中if(Head->number==key)

{

Head=Pointer->next;

free(Pointer);

break;

}

Back = Pointer;

Pointer=Pointer->next;

if(Pointer->number==key)

{

Back->next=Pointer->next;

free(Pointer);

break;

}

void delete(Node* p)

{

if(Head = Node)

while(p)

}

有一個16位的整數(shù),每4位為一個數(shù),寫函數(shù)求他們的和。

解釋:

整數(shù)1101010110110111

和 1101+0101+1011+0111

感覺應該不難,當時對題理解的不是很清楚,所以寫了一個函數(shù),也不知道對不對。

疑問:

既然是16位的整數(shù),1101010110110111是2進制的,那么函數(shù)參數(shù)怎么定義呢,請大蝦指教。

答案:用十進制做參數(shù),計算時按二進制考慮。

/* n就是16位的數(shù),函數(shù)返回它的四個部分之和 */

char SumOfQuaters(unsigned short n)

{

char c = 0;

int i = 4;

do

{

c += n & 15;

n = n >> 4;

} while (--i);

return c;

}

有1,2,....一直到n的無序數(shù)組,求排序算法,并且要求時間復雜度為O(n),空間復雜度O(1),使用交換,而且一次只能交換兩個數(shù).(華為)

#i nclude

int main()

{

int a[] = {10,6,9,5,2,8,4,7,1,3};

int len = sizeof(a) / sizeof(int);

int temp;

for(int i = 0; i < len; )

{

temp = a[a[i] - 1];

a[a[i] - 1] = a[i];

a[i] = temp;

if ( a[i] == i + 1)

i++;

}

for (int j = 0; j < len; j++)

cout<

return 0;

}

華為面試題:怎么判斷鏈表中是否有環(huán)?

bool CircleInList(Link* pHead)

{

if(pHead = = NULL || pHead->next = = NULL)//無節(jié)點或只有一個節(jié)點并且無自環(huán)

return (false);

if(pHead->next = = pHead)//自環(huán)

return (true);

Link *pTemp1 = pHead;//step 1

Link *pTemp = pHead->next;//step 2

while(pTemp != pTemp1 && pTemp != NULL && pTemp->next != NULL)

{

pTemp1 = pTemp1->next;

pTemp = pTemp->next->next;

}

if(pTemp = = pTemp1)

return (true);

return (false);

}

兩個字符串,s,t;把t字符串插入到s字符串中,s字符串有足夠的空間存放t字符串

void insert(char *s, char *t, int i)

{

memcpy(&s[strlen(t)+i],&s[i],strlen(s)-i);

memcpy(&s[i],t,strlen(t));

s[strlen(s)+strlen(t)]='\0';

}

1。編寫一個 C 函數(shù),該函數(shù)在一個字符串中找到可能的最長的子字符串,且該字符串是由同一字符組成的。

char * search(char *cpSource, char ch)

{

char *cpTemp=NULL, *cpDest=NULL;

int iTemp, iCount=0;

while(*cpSource)

{

if(*cpSource == ch)

{

iTemp = 0;

cpTemp = cpSource;

while(*cpSource == ch)

++iTemp, ++cpSource;

if(iTemp > iCount)

iCount = iTemp, cpDest = cpTemp;

if(!*cpSource)

break;

}

++cpSource;

}

return cpDest;

}

2。請編寫一個 C 函數(shù),該函數(shù)在給定的內(nèi)存區(qū)域搜索給定的字符,并返回該字符所在位置索引值。

int search(char *cpSource, int n, char ch)

{

int i;

for(i=0; i

return i;

}

一個單向鏈表,不知道頭節(jié)點,一個指針指向其中的一個節(jié)點,問如何刪除這個指針指向的節(jié)點?

將這個指針指向的next節(jié)點值copy到本節(jié)點,將next指向next->next,并隨后刪除原next指向的節(jié)點。

#i nclude

void foo(int m, int n)

{

printf("m=%d, n=%d\n", m, n);

}

int main()

{

int b = 3;

foo(b+=3, ++b);

printf("b=%d\n", b);

return 0;

}

輸出:m=7,n=4,b=7(VC6.0)

這種方式和編譯器中得函數(shù)調(diào)用關系相關即先后入棧順序。不過不同

編譯器得處理不同。也是因為C標準中對這種方式說明為未定義,所以

各個編譯器廠商都有自己得理解,所以最后產(chǎn)生得結果完全不同。

因為這樣,所以遇見這種函數(shù),我們首先要考慮我們得編譯器會如何處理

這樣得函數(shù),其次看函數(shù)得調(diào)用方式,不同得調(diào)用方式,可能產(chǎn)生不同得

結果。最后是看編譯器優(yōu)化。

2.寫一函數(shù),實現(xiàn)刪除字符串str1中含有的字符串str2.

第二個就是利用一個KMP匹配算法找到str2然后刪除(用鏈表實現(xiàn)的話,便捷于數(shù)組)

==============================================================================

微軟亞洲技術中心的面試題!!!

1.進程和線程的差別。

線程是指進程內(nèi)的一個執(zhí)行單元,也是進程內(nèi)的可調(diào)度實體.

與進程的區(qū)別:

(1)調(diào)度:線程作為調(diào)度和分配的基本單位,進程作為擁有資源的基本單位

(2)并發(fā)性:不僅進程之間可以并發(fā)執(zhí)行,同一個進程的多個線程之間也可并發(fā)執(zhí)行

(3)擁有資源:進程是擁有資源的一個獨立單位,線程不擁有系統(tǒng)資源,但可以訪問隸屬于進程的資源.

(4)系統(tǒng)開銷:在創(chuàng)建或撤消進程時,由于系統(tǒng)都要為之分配和回收資源,導致系統(tǒng)的開銷明顯大于創(chuàng)建或撤消線程時的開銷。

2.測試方法

人工測試:個人復查、抽查和會審

機器測試:黑盒測試和白盒測試

2.Heap與stack的差別。

Heap是堆,stack是棧。

Stack的空間由操作系統(tǒng)自動分配/釋放,Heap上的空間手動分配/釋放。

Stack空間有限,Heap是很大的自由存儲區(qū)

C中的malloc函數(shù)分配的內(nèi)存空間即在堆上,C++中對應的是new操作符。

程序在編譯期對變量和函數(shù)分配內(nèi)存都在棧上進行,且程序運行過程中函數(shù)調(diào)用時參數(shù)的傳遞也在棧上進行

3.Windows下的內(nèi)存是如何管理的?

4.介紹.Net和.Net的安全性。

5.客戶端如何訪問.Net組件實現(xiàn)Web Service?

6.C/C++編譯器中虛表是如何完成的?

7.談談COM的線程模型。然后討論進程內(nèi)/外組件的差別。

8.談談IA32下的分頁機制

小頁(4K)兩級分頁模式,大頁(4M)一級

9.給兩個變量,如何找出一個帶環(huán)單鏈表中是什么地方出現(xiàn)環(huán)的?

一個遞增一,一個遞增二,他們指向同一個接點時就是環(huán)出現(xiàn)的地方

10.在IA32中一共有多少種辦法從用戶態(tài)跳到內(nèi)核態(tài)?

通過調(diào)用門,從ring3到ring0,中斷從ring3到ring0,進入vm86等等

11.如果只想讓程序有一個實例運行,不能運行兩個。像winamp一樣,只能開一個窗口,怎樣實現(xiàn)?

用內(nèi)存映射或全局原子(互斥變量)、查找窗口句柄..

FindWindow,互斥,寫標志到文件或注冊表,共享內(nèi)存。.

12.如何截取鍵盤的響應,讓所有的‘a’變成‘b’?

鍵盤鉤子SetWindowsHookEx

13.Apartment在COM中有什么用?為什么要引入?

14.存儲過程是什么?有什么用?有什么優(yōu)點?

我的理解就是一堆sql的集合,可以建立非常復雜的查詢,編譯運行,所以運行一次后,以后再運行速度比單獨執(zhí)行SQL快很多

15.Template有什么特點?什么時候用?

16.談談Windows DNA結構的特點和優(yōu)點。

網(wǎng)絡編程中設計并發(fā)服務器,使用多進程 與 多線程 ,請問有什么區(qū)別?

1,進程:子進程是父進程的復制品。子進程獲得父進程數(shù)據(jù)空間、堆和棧的復制品。

2,線程:相對與進程而言,線程是一個更加接近與執(zhí)行體的概念,它可以與同進程的其他線程共享數(shù)據(jù),但擁有自己的棧空間,擁有獨立的執(zhí)行序列。

兩者都可以提高程序的并發(fā)度,提高程序運行效率和響應時間。

線程和進程在使用上各有優(yōu)缺點:線程執(zhí)行開銷小,但不利于資源管理和保護;而進程正相反。同時,線程適合于在SMP機器上運行,而進程則可以跨機器遷移。

===============================================================================

思科

1. 用宏定義寫出swap(x,y)

#define swap(x, y)\

x = x + y;\

y = x - y;\

x = x - y;

2.數(shù)組a[N],存放了1至N-1個數(shù),其中某個數(shù)重復一次。寫一個函數(shù),找出被重復的數(shù)字.時間復雜度必須為o(N)函數(shù)原型:

int do_dup(int a[],int N)

3 一語句實現(xiàn)x是否為2的若干次冪的判斷

int i = 512;

cout << boolalpha << ((i & (i - 1)) ? false : true) << endl;

4.unsigned int intvert(unsigned int x,int p,int n)實現(xiàn)對x的進行轉換,p為起始轉化位,n為需要轉換的長度,假設起始點在右邊.如x=0b0001 0001,p=4,n=3轉換后x=0b0110 0001

unsigned int intvert(unsigned int x,int p,int n){

unsigned int _t = 0;

unsigned int _a = 1;

for(int i = 0; i < n; ++i){

_t |= _a;

_a = _a << 1;

}

_t = _t << p;

x ^= _t;

return x;

}

上一篇:重慶博澳特C語言經(jīng)典筆試題

下一篇:嵌入式企業(yè)面試題匯總,還不趕快收藏起來

熱點文章推薦
華清學員就業(yè)榜單
高薪學員經(jīng)驗分享
熱點新聞推薦
前臺專線:010-82525158 企業(yè)培訓洽談專線:010-82525379 院校合作洽談專線:010-82525379 Copyright © 2004-2022 北京華清遠見科技集團有限公司 版權所有 ,京ICP備16055225號-5京公海網(wǎng)安備11010802025203號

回到頂部

主站蜘蛛池模板: 南贤俊| 黑木郁美| 名剑 电影| 永远的经典影片永远的| 周柯宇个人资料| 向团组织靠拢的打算| 情人意大利| 蒋昌义| 青草在线视频| 寒战2剧情解析| 家庭理论电影| 同性gay在线| 下巴有个凹陷| 一号皇庭| 如意电视剧| 都市女孩| 茶馆剧本完整版| 电影红旗谱| 小狗克罗历险记| 天津电视台体育频道节目单| 《起风了》数字简谱| 电影危机航线什么时候上映| 韩寒| 铁血使命电视剧演员表| 红星闪闪简谱| christie stevens| 高登眼镜| 美食总动员在线观看完整版免费| 乱世枭雄评书485集免费| 竹内纱里奈全部aⅴ在线看| 洛可希佛帝的电影| 火烈鸟电影完整版视频| 安娜卡列琳娜| xxxxxxxxxxxxx| 张小波的个人资料简介| 动漫秀场| 黄色网址视频| 无限资源日本好片| 虐猫视频哪里可以看| 道东道西| 郑艳丽的经典电影|