當(dāng)前位置:首頁(yè) > 嵌入式培訓(xùn) > 嵌入式招聘 > 嵌入式面試題 > 嵌入式C語(yǔ)言面試題大集合,都是自己總結(jié)的
現(xiàn)在發(fā)展最快的也就是IT行業(yè)了,嵌入式就是其中之一,很多剛學(xué)出來(lái)的去找工作,一般都會(huì)是被面試題給難住了,與理想工作失之交臂,我面試了那么多家,總結(jié)出了一點(diǎn)規(guī)律,一般C語(yǔ)言是必考的,題里面必有的,今天我總結(jié)出來(lái)一下C語(yǔ)言面試題,希望可以幫到你。
1. 關(guān)鍵字static有什么用途?(請(qǐng)至少說(shuō)明兩種)
1.限制變量的作用域2.設(shè)置變量的存儲(chǔ)域
2. 引用與指針有什么區(qū)別?
1) 引用必須被初始化,指針不必。
2) 引用初始化以后不能被改變,指針可以改變所指的對(duì)象。
2) 不存在指向空值的引用,但是存在指向空值的指針。NULL
3. 描述實(shí)時(shí)系統(tǒng)的基本特性
在特定時(shí)間內(nèi)完成特定的任務(wù),實(shí)時(shí)性與可靠性
5. 什么是平衡二叉樹?
左右子樹都是平衡二叉樹 且左右子樹的深度差值的絕對(duì)值不大于1
6. 堆棧溢出一般是由什么原因?qū)е碌?
沒(méi)有回收垃圾資源
7. 什么函數(shù)不能聲明為虛函數(shù)?
構(gòu)造函數(shù),因?yàn)樗窃趯?duì)象產(chǎn)生之頭被調(diào)用的,而虛函數(shù)是對(duì)象產(chǎn)生之后才起作用的機(jī)制,所以聲明虛構(gòu)造函數(shù)無(wú)意義。
8. 冒泡排序算法的時(shí)間復(fù)雜度是什么?
O(n^2)
9 寫出float x 與“零值”比較的if語(yǔ)句。
if(x>0.000001&&x<-0.000001)//見(jiàn)高質(zhì)量C++編程一書
10. Internet采用哪種網(wǎng)絡(luò)協(xié)議?該協(xié)議的主要層次結(jié)構(gòu)?
tcp/ip 應(yīng)用層/傳輸層/網(wǎng)絡(luò)層/鏈路層
11. Internet物理地址和IP地址轉(zhuǎn)換采用什么協(xié)議?
ARP (Address Resolution Protocol )
12. IP地址的編碼分為哪倆部分?
IP地址由兩部分組成,網(wǎng)絡(luò)號(hào)和主機(jī)號(hào)。不過(guò)是要和“子網(wǎng)掩碼”按位與上之后才能區(qū)分哪些是網(wǎng)絡(luò)位哪些是主機(jī)位。
13. 不能做switch()的參數(shù)類型是:
實(shí)型。
14、局部變量能否和全局變量重名?
答:能,局部會(huì)屏蔽全局。要用全局變量,需要使用"::"
局部變量可以與全局變量同名,在函數(shù)內(nèi)引用這個(gè)變量時(shí),會(huì)用到同名的局部變量,而不會(huì)用到全局變量。對(duì)于有些編譯器而言,在同一個(gè)函數(shù)內(nèi)可以定義多個(gè)同名的局部變量,比如在兩個(gè)循環(huán)體內(nèi)都定義一個(gè)同名的局部變量,而那個(gè)局部變量的作用域就在那個(gè)循環(huán)體內(nèi)
15、如何引用一個(gè)已經(jīng)定義過(guò)的全局變量?
答:extern關(guān)鍵字
可以用引用頭文件的方式,也可以用extern關(guān)鍵字,如果用引用頭文件方式來(lái)引用某個(gè)在頭文件中聲明的全局變理,假定你將那個(gè)變寫錯(cuò)了,那么在編譯期間會(huì)報(bào)錯(cuò),如果你用extern方式引用時(shí),假定你犯了同樣的錯(cuò)誤,那么在編譯期間不會(huì)報(bào)錯(cuò),而在連接期間報(bào)錯(cuò)。
16、全局變量可不可以定義在可被多個(gè).C文件包含的頭文件中?為什么?
答:可以,在不同的C文件中以static形式來(lái)聲明同名全局變量。
可以在不同的C文件中聲明同名的全局變量,前提是其中只能有一個(gè)C文件中對(duì)此變量賦初值,此時(shí)連接不會(huì)出錯(cuò)
17、static全局變量與普通的全局變量有什么區(qū)別?static局部變量和普通局部變量有什么區(qū)別?static函數(shù)與普通函數(shù)有什么區(qū)別?
全局變量(外部變量)的說(shuō)明之前再冠以static 就構(gòu)成了靜態(tài)的全局變量。全局變量本身就是靜態(tài)存儲(chǔ)方式, 靜態(tài)全局變量當(dāng)然也是靜態(tài)存儲(chǔ)方式。這兩者在存儲(chǔ)方式上并無(wú)不同。這兩者的區(qū)別雖在于非靜態(tài)全局變量的作用域是整個(gè)源程序,當(dāng)一個(gè)源程序由多個(gè)源文件組成時(shí),非靜態(tài)的全局變量在各個(gè)源文件中都是有效的。 而靜態(tài)全局變量則限制了其作用域, 即只在定義該變量的源文件內(nèi)有效,在同一源程序的其它源文件中不能使用它。由于靜態(tài)全局變量的作用域局限于一個(gè)源文件內(nèi),只能為該源文件內(nèi)的函數(shù)公用,因此可以避免在其它源文件中引起錯(cuò)誤。
從以上分析可以看出, 把局部變量改變?yōu)殪o態(tài)變量后是改變了它的存儲(chǔ)方式即改變了它的生存期。把全局變量改變?yōu)殪o態(tài)變量后是改變了它的作用域, 限制了它的使用范圍。
static函數(shù)與普通函數(shù)作用域不同。僅在本文件。只在當(dāng)前源文件中使用的函數(shù)應(yīng)該說(shuō)明為內(nèi)部函數(shù)(static),內(nèi)部函數(shù)應(yīng)該在當(dāng)前源文件中說(shuō)明和定義。對(duì)于可在當(dāng)前源文件以外使用的函數(shù),應(yīng)該在一個(gè)頭文件中說(shuō)明,要使用這些函數(shù)的源文件要包含這個(gè)頭文件
static全局變量與普通的全局變量有什么區(qū)別:static全局變量只初使化一次,防止在其他文件單元中被引用;
static局部變量和普通局部變量有什么區(qū)別:static局部變量只被初始化一次,下一次依據(jù)上一次結(jié)果值;
static函數(shù)與普通函數(shù)有什么區(qū)別:static函數(shù)在內(nèi)存中只有一份,普通函數(shù)在每個(gè)被調(diào)用中維持一份拷貝
程序的局部變量存在于(棧)中,全局變量存在于(靜態(tài)區(qū))中,動(dòng)態(tài)申請(qǐng)數(shù)據(jù)存在于(堆)中。
18、設(shè)有以下說(shuō)明和定義:
typedef union {long i; int k[5]; char c;} DATE;
struct data { int cat; DATE cow; double dog;} too;
DATE max;
則語(yǔ)句 printf("%d",sizeof(struct date)+sizeof(max));的執(zhí)行結(jié)果是:
答:
16位編譯器中,union = 5*2 = 10
data = int 2 + 10 + 8 = 20
此時(shí)結(jié)果為30
32位編譯器中:union = 5*4 = 20
Data = int 4+ union 20 + double 8 = 32
此時(shí)結(jié)果為52
19、寫出下列代碼的輸出內(nèi)容(簡(jiǎn)單)
typedef int(FUNC1)(int in); //自定義函數(shù)類型,注意要與函數(shù)指針的定義形式分開(kāi)。
typedef int(FUNC2) (int*,int*,int*);
int inc(int a)
{ return(++a); }
int multi(int*a,int*b,int*c)
{ return(*c=*a**b); }
void show(FUNC2 fun, int arg1, int *arg2) //回調(diào)函數(shù)
{
int temp = arg1;
arg1 = inc(arg1);
fun(&temp,&arg1, arg2);
printf("%d\n",*arg2);
}
main()
{
int a;
show(multi,10,&a);
return 0;
}
答:110
20、下面的代碼的目的是把一個(gè)字符串倒序,如“abcd”倒序后變?yōu)?ldquo;dcba”,請(qǐng)找出所有錯(cuò)誤。
1、#include"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分配一個(gè)空間
char* d = dest;
char* s = &src[len-1];//指向最后一個(gè)字符
while( len-- != 0 )
*d++=*s--;
*d = 0;//尾部要加\0
printf("%s\n",dest);
free(dest);// 使用完,應(yīng)當(dāng)釋放空間,以免造成內(nèi)存泄露
return 0;
}
方法2:
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;
}
21.用兩個(gè)棧實(shí)現(xiàn)一個(gè)隊(duì)列的功能?要求給出算法和思路(思路題,有用)
設(shè)2個(gè)棧為A,B, 一開(kāi)始均為空.
入隊(duì):
將新元素push入棧A;
出隊(duì):
(1)判斷棧B是否為空;
(2)如果不為空,則將棧B中最頂元素pop出;如果為空,則將A中所有元素POP出并PUSH到B中,這后POP出最頂元素,A則下移一單位。
2.對(duì)于一個(gè)頻繁使用的短小函數(shù),在C語(yǔ)言中應(yīng)用什么實(shí)現(xiàn),在C++中應(yīng)用什么實(shí)現(xiàn)?
c用宏定義,c++用inline
6.軟件測(cè)試都有那些種類?
黑盒:針對(duì)系統(tǒng)功能的測(cè)試 白合:測(cè)試函數(shù)功能,各函數(shù)接口
7.確定模塊的功能和模塊的接口是在軟件設(shè)計(jì)的那個(gè)隊(duì)段完成的?
概要設(shè)計(jì)階段
三.選擇題:
1.Ethternet鏈接到Internet用到以下那個(gè)協(xié)議?
A.HDLC; B.ARP; C.UDP; D.TCP; E.ID 選A
2.屬于網(wǎng)絡(luò)層協(xié)議的是:
A.TCP;B.IP;C.ICMP;D.X.25 選B
3.Windows消息調(diào)度機(jī)制是:
A.指令隊(duì)列;B.指令堆棧;C.消息隊(duì)列;D.消息堆棧; 選C
四.找錯(cuò)題:
2.#define Max_CB 500
void LmiQueryCSmd(Struct MSgCB * pmsg)
{
nsigned char ucCmdNum;
for(ucCmdNum=0;ucCmdNum
{
......;
}
死循環(huán)
3.以下是求一個(gè)數(shù)的平方的程序,請(qǐng)找出錯(cuò)誤:
#define SQUARE(a)((a)*(a))
int a=5;
int b;
b=SQUARE(a++);
注意:此題是有歧義的,屬于有問(wèn)題的代碼,要盡量避免寫這樣的代碼。因?yàn)楫?dāng)一個(gè)句子中有多個(gè)++操作符時(shí),在不同的編譯器里,運(yùn)算順序可能是不一樣的,還有可能相互影響。
上面的代碼中,“b=SQUARE(++a)”語(yǔ)句經(jīng)預(yù)處理后,變?yōu)閎= ((++a)*(++a)),兩次++后a的值變?yōu)?,故最后的結(jié)果是“b = 7*7”,而不是原先設(shè)定的“b = 6*6”。
2.TCP/IP通信建立的過(guò)程怎樣,端口有什么作用?
三次握手,確定哪個(gè)應(yīng)用程序使用該協(xié)議