?? c語言面試題大全.txt
字號:
C語言面試題大匯總
4. static有什么用途?(請至少說明兩種)
1.限制變量的作用域(DL:使其只在定義的當(dāng)前文件中起作用,static是只能由與變量在同一個文件中定義的程序
存取的全局變量。也就是說使全局變量成為文件的私有變量,以致其他文件不可以通過將它們定義為extern而存
取這些變量。)
2.設(shè)置變量的存儲域(DL:存儲在最開始的靜態(tài)存儲空間里面)
7. 引用與指針有什么區(qū)別?
1) 引用必須被初始化,指針不必。
2) 引用初始化以后不能被改變,指針可以改變所指的對象。
2) 不存在指向空值的引用,但是存在指向空值的指針。
8. 描述實時系統(tǒng)的基本特性
在特定時間內(nèi)完成特定的任務(wù),實時性與可靠性
9. 全局變量和局部變量在內(nèi)存中是否有區(qū)別?如果有,是什么區(qū)別?
全局變量儲存在靜態(tài)數(shù)據(jù)庫,局部變量在堆棧
10. 什么是平衡二叉樹?
左右子樹都是平衡二叉樹 且左右子樹的深度差值的絕對值不大于1
11. 堆棧溢出一般是由什么原因?qū)е碌模?沒有回收垃圾資源
12. 什么函數(shù)不能聲明為虛函數(shù)?
constructor
13. 冒泡排序算法的時間復(fù)雜度是什么?
O(n^2)
14. 寫出float x 與“零值”比較的if語句。
if(x>0.000001&&x<-0.000001)
16. Internet采用哪種網(wǎng)絡(luò)協(xié)議?該協(xié)議的主要層次結(jié)構(gòu)?
tcp/ip 應(yīng)用層/傳輸層/網(wǎng)絡(luò)層/數(shù)據(jù)鏈路層/物理層
17. Internet物理地址和IP地址轉(zhuǎn)換采用什么協(xié)議?
ARP (Address Resolution Protocol)(地址解析協(xié)議)
18.IP地址的編碼分為哪倆部分?
IP地址由兩部分組成,網(wǎng)絡(luò)號和主機(jī)號。不過是要和“子網(wǎng)掩碼”按位與上之后才能區(qū)分
哪些是網(wǎng)絡(luò)位哪些是主機(jī)位。
2.用戶輸入M,N值,從1至N開始順序循環(huán)數(shù)數(shù),每數(shù)到M輸出該數(shù)值,直至全部輸出。寫出
C程序。
循環(huán)鏈表,用取余操作做
3.不能做switch()的參數(shù)類型是:
switch的參數(shù)不能為實型。
華為
1、局部變量能否和全局變量重名?
答:能,局部會屏蔽全局。要用全局變量,需要使用"::"
局部變量可以與全局變量同名,在函數(shù)內(nèi)引用這個變量時,會用到同名的局部變量,而不
會用到全局變量。對于有些編譯器而言,在同一個函數(shù)內(nèi)可以定義多個同名的局部變量,
比如在兩個循環(huán)體內(nèi)都定義一個同名的局部變量,而那個局部變量的作用域就在那個循環(huán)
體內(nèi)
2、如何引用一個已經(jīng)定義過的全局變量?
答:extern(在使用該變量的地方還要定義一次,extern只相當(dāng)于聲明,且只能在函數(shù)體外定義)/
static(在使用時不用定義,且作用域限制在當(dāng)前源文件,且只能在函數(shù)體內(nèi)重新賦值)
可以用引用頭文件的方式(必須用static聲明),也可以用extern關(guān)鍵字,如果用引用頭文件方式來引用某個在
頭文件中聲明的全局變理,假定你將那個變寫錯了,那么在編譯期間會報錯,如果你用ex
tern方式引用時,假定你犯了同樣的錯誤,那么在編譯期間不會報錯,而在連接期間報錯
3、全局變量可不可以定義在可被多個.C文件包含的頭文件中?為什么?
答:可以,在不同的C文件中以static形式來聲明同名全局變量。
可以在不同的C文件中聲明同名的全局變量,前提是其中只能有一個C文件中對此變量賦初
值,此時連接不會出錯
4、語句for( ;1 ;)有什么問題?它是什么意思?
答:和while(1)相同。
5、do……while和while……do有什么區(qū)別?
答:前一個循環(huán)一遍再判斷,后一個判斷以后再循環(huán)
6、請寫出下列代碼的輸出內(nèi)容
#include<stdio.h>
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 就構(gòu)成了靜態(tài)的全局變量。全局變量本身就
是靜態(tài)存儲方式, 靜態(tài)全局變量當(dāng)然也是靜態(tài)存儲方式。 這兩者在存儲方式上并無不同
。這兩者的區(qū)別雖在于非靜態(tài)全局變量的作用域是整個源程序, 當(dāng)一個源程序由多個源文
件組成時,非靜態(tài)的全局變量在各個源文件中都是有效的。 而靜態(tài)全局變量則限制了其作
用域, 即只在定義該變量的源文件內(nèi)有效, 在同一源程序的其它源文件中不能使用它。
由于靜態(tài)全局變量的作用域局限于一個源文件內(nèi),只能為該源文件內(nèi)的函數(shù)公用, 因此可
以避免在其它源文件中引起錯誤。
從以上分析可以看出, 把局部變量改變?yōu)殪o態(tài)變量后是改變了它的存儲方式即改變了它的
生存期(靜態(tài)局部變量在程序運(yùn)行結(jié)束釋放空間,而普通靜態(tài)局部變量在函數(shù)退出時釋放空間)。
把全局變量改變?yōu)殪o態(tài)變量后是改變了它的作用域, 限制了它的使用范圍。
static函數(shù)與普通函數(shù)作用域不同。僅在本文件。只在當(dāng)前源文件中使用的函數(shù)應(yīng)該說明
為內(nèi)部函數(shù)(static),內(nèi)部函數(shù)應(yīng)該在當(dāng)前源文件中說明和定義。對于可在當(dāng)前源文件以
外使用的函數(shù),應(yīng)該在一個頭文件中說明,要使用這些函數(shù)的源文件要包含這個頭文件
(用static聲明的即內(nèi)部函數(shù),內(nèi)部函數(shù)指只能被本文件的其他函數(shù)所調(diào)用的函數(shù),
內(nèi)部函數(shù)在C++實際上可以通過類名修飾符訪問
其他均為外部函數(shù))
static全局變量與普通的全局變量有什么區(qū)別:static全局變量只初使化一次,防止在其
他文件單元中被引用;
static局部變量和普通局部變量有什么區(qū)別:static局部變量只被初始化一次,下一次依
據(jù)上一次結(jié)果值;
static函數(shù)與普通函數(shù)有什么區(qū)別:static函數(shù)在內(nèi)存中只有一份,普通函數(shù)在每個被調(diào)
用中維持一份拷貝
2、程序的局部變量存在于(堆棧)中,全局變量存在于(靜態(tài)區(qū) )中,動態(tài)申請數(shù)據(jù)存
在于( 堆)中。
3、設(shè)有以下說明和定義:
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í)行結(jié)果是:___52____
答:DATE是一個union, 變量公用空間. 里面最大的變量類型是int[5], 占用20個字節(jié). 所
以它的大小是20
data是一個struct, 每個變量分開占用空間. 依次為int4 + DATE20 + double8 = 32.
所以結(jié)果是 20 + 32 = 52.
當(dāng)然...在某些16位編輯器下, int可能是2字節(jié),那么結(jié)果是 int2 + DATE10 + double8 =
20
4、隊列和棧有什么區(qū)別?
隊列先進(jìn)先出,棧后進(jìn)先出
5、寫出下列代碼的輸出內(nèi)容
#include<stdio.h>
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)椤癲cba”
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分配一個空間
char* d = dest;
char* s = &src[len-1];//指向最后一個字符
while( len-- != 0 )
*d++=*s--;
*d = 0;//尾部要加\0
printf("%s\n",dest);
free(dest);// 使用完,應(yīng)當(dāng)釋放空間,以免造成內(nèi)存匯泄露
return 0;
}
方法2:
#include <stdio.h>
#include <string.h>
main()
{
char str[]="hello,world";
int len=strlen(str);
char t;
for(int i=0; i<len/2; 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ù)是什么?為什么?
第一題的答案應(yīng)該是4^3-1=63
規(guī)律是n^3-1(當(dāng)n為偶數(shù)0,2,4)
n^3+1(當(dāng)n為奇數(shù)1,3,5)
答案:63
2.用兩個棧實現(xiàn)一個隊列的功能?要求給出算法和思路!
設(shè)2個棧為A,B, 一開始均為空.
入隊:
將新元素push入棧A;
出隊:
(1)判斷棧B是否為空;
(2)如果不為空,則將棧A中所有元素依次pop出并push到棧B;
(3)將棧B的棧頂元素pop出;
這樣實現(xiàn)的隊列入隊和出隊的平攤復(fù)雜度都還是O(1), 比上面的幾種方法要好。
3.在c語言庫函數(shù)中將一個字符轉(zhuǎn)換成整型的函數(shù)是atool()嗎,這個函數(shù)的原型是什么?
函數(shù)名: atol
功 能: 把字符串轉(zhuǎn)換成長整型數(shù)
用 法: long atol(const char *nptr);
程序例:
#include <stdlib.h>
#include <stdio.h>
int main(void)
{
long l;
char *str = "98765432";
l = atol(lstr);
printf("string = %s integer = %ld\n", str, l);
return(0);
}
2.對于一個頻繁使用的短小函數(shù),在C語言中應(yīng)用什么實現(xiàn),在C++中應(yīng)用什么實現(xiàn)?
c用宏定義,c++用inline
3.直接鏈接兩個信令點(diǎn)的一組鏈路稱作什么?
PPP點(diǎn)到點(diǎn)連接
4.接入網(wǎng)用的是什么接口?
DL:接入網(wǎng)在接入這些網(wǎng)絡(luò)時,一般采用E1、V.24、V.35、2B1Q“U”接口,其余類型的接口使用較少。
5.voip都用了那些協(xié)議?
VoIP使用IETF會話發(fā)起協(xié)議(SIP)和實時傳輸協(xié)議(RTP)提交呼叫信令和語音消息
與VoIP相關(guān)的網(wǎng)絡(luò)技術(shù)協(xié)議很多,常見的有控制實時數(shù)據(jù)流應(yīng)用在IP網(wǎng)絡(luò)傳輸?shù)腞TP(實時傳輸協(xié)議)和RTCP(實時
傳輸控制協(xié)議);
有保證網(wǎng)絡(luò)QoS質(zhì)量服務(wù)的RSVP(資源預(yù)留協(xié)議)和IP different Service等,
還有傳統(tǒng)語音數(shù)字化編碼的一系列協(xié)議如G.711、G.728、G.723、G.729等等。
但目前VoIP技術(shù)最常用的話音建立和控制信令是H.323和SIP(會話初始協(xié)議)。
6.軟件測試都有那些種類?
黑盒:針對系統(tǒng)功能的測試 白合:測試函數(shù)功能,各函數(shù)接口
7.確定模塊的功能和模塊的接口是在軟件設(shè)計的那個隊段完成的?
概要設(shè)計階段
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= 0x801005;
p2+5= 0x810014(加5*4=20字節(jié),16進(jìn)制為0x14);
三.選擇題:
1.Ethternet鏈接到Internet用到以下那個協(xié)議?
A.HDLC;B.ARP;C.UDP;D.TCP;E.ID
2.屬于網(wǎng)絡(luò)層協(xié)議的是:
A.TCP;B.IP;C.ICMP;D.X.25
3.Windows消息調(diào)度機(jī)制是:
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)外換一下(DL:換一下好像還是有錯)
2.#define Max_CB 500
void LmiQueryCSmd(Struct MSgCB * pmsg)
{
unsigned char ucCmdNum;
......
for(ucCmdNum=0;ucCmdNum<Max_CB;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通信建立的過程怎樣,端口有什么作用?
三次握手,確定是哪個應(yīng)用程序使用該協(xié)議
3.1號信令和7號信令有什么區(qū)別,我國某前廣泛使用的是那一種?
七號信令網(wǎng)是電話網(wǎng)、智能網(wǎng)以及各種新業(yè)務(wù)的神經(jīng)和支撐網(wǎng),是通信網(wǎng)建設(shè)維護(hù)的重要部分。根據(jù)我國七號信
令技術(shù)體制要求,我國七號信令網(wǎng)最終采用三級準(zhǔn)直聯(lián)結(jié)構(gòu)方式。
1號信令利用TS16傳送時。每個TS16負(fù)責(zé)傳送兩個話路的線路信令,TS16和話路有著固定的一一對應(yīng)關(guān)系。
而7號信令利用TS16來傳送時,只是將組成信令單元的若干個8位位組,依次插入TS16,TS16并不知道傳送的內(nèi)容
,
即信令和話路沒有固定關(guān)系,只不過利用TS16作為傳送信令的載體,時傳送信令消息的數(shù)據(jù)鏈路,
因此,選用哪個時隙做數(shù)據(jù)鏈路均可。 --- 這也是隨路信令和公共信道信令的一個本質(zhì)區(qū)別。
4.列舉5種以上的電話新業(yè)務(wù)?
微軟亞洲技術(shù)中心的面試題?。?!
1.進(jìn)程和線程的差別。
線程是指進(jìn)程內(nèi)的一個執(zhí)行單元,也是進(jìn)程內(nèi)的可調(diào)度實體.
與進(jìn)程的區(qū)別:
(1)調(diào)度:線程作為調(diào)度和分配的基本單位,進(jìn)程作為擁有資源的基本單位
(2)并發(fā)性:不僅進(jìn)程之間可以并發(fā)執(zhí)行,同一個進(jìn)程的多個線程之間也可并發(fā)執(zhí)行
(3)擁有資源:進(jìn)程是擁有資源的一個獨(dú)立單位,線程不擁有系統(tǒng)資源,但可以訪問隸屬于
進(jìn)程的資源.
(4)系統(tǒng)開銷:在創(chuàng)建或撤消進(jìn)程時,由于系統(tǒng)都要為之分配和回收資源,導(dǎo)致系統(tǒng)的開銷
明顯大于創(chuàng)建或撤消線程時的開銷。
2.測試方法
人工測試:個人復(fù)查、抽查和會審
機(jī)器測試:黑盒測試和白盒測試
2.Heap與stack的差別。
Heap是堆,stack是棧。
Stack的空間由操作系統(tǒng)自動分配/釋放,Heap上的空間手動分配/釋放。
Stack空間有限,Heap是很大的自由存儲區(qū)
C中的malloc函數(shù)分配的內(nèi)存空間即在堆上,C++中對應(yīng)的是new操作符。
程序在編譯期對變量和函數(shù)分配內(nèi)存都在棧上進(jìn)行,且程序運(yùn)行過程中函數(shù)調(diào)用時參數(shù)的傳
遞也在棧上進(jìn)行
3.Windows下的內(nèi)存是如何管理的?
4.介紹.Net和.Net的安全性。
5.客戶端如何訪問.Net組件實現(xiàn)Web Service?
6.C/C++編譯器中虛表是如何完成的?
7.談?wù)凜OM的線程模型。然后討論進(jìn)程內(nèi)/外組件的差別。
8.談?wù)処A32下的分頁機(jī)制
小頁(4K)兩級分頁模式,大頁(4M)一級
9.給兩個變量,如何找出一個帶環(huán)單鏈表中是什么地方出現(xiàn)環(huán)的?
一個遞增一,一個遞增二,他們指向同一個接點(diǎn)時就是環(huán)出現(xiàn)的地方
10.在IA32中一共有多少種辦法從用戶態(tài)跳到內(nèi)核態(tài)?
通過調(diào)用門,從ring3到ring0,中斷從ring3到ring0,進(jìn)入vm86等等
11.如果只想讓程序有一個實例運(yùn)行,不能運(yùn)行兩個。像winamp一樣,只能開一個窗口,
怎樣實現(xiàn)?
用內(nèi)存映射或全局原子(互斥變量)、查找窗口句柄..
FindWindow,互斥,寫標(biāo)志到文件或注冊表,共享內(nèi)存。.
12.如何截取鍵盤的響應(yīng),讓所有的‘a(chǎn)’變成‘b’?
鍵盤鉤子SetWindowsHookEx
13.Apartment在COM中有什么用?為什么要引入?
14.存儲過程是什么?有什么用?有什么優(yōu)點(diǎn)?
我的理解就是一堆sql的集合,可以建立非常復(fù)雜的查詢,編譯運(yùn)行,所以運(yùn)行一次后,以
后再運(yùn)行速度比單獨(dú)執(zhí)行SQL快很多
15.Template有什么特點(diǎn)?什么時候用?
16.談?wù)刉indows DNA結(jié)構(gòu)的特點(diǎn)和優(yōu)點(diǎn)。
網(wǎng)絡(luò)編程中設(shè)計并發(fā)服務(wù)器,使用多進(jìn)程 與 多線程 ,請問有什么區(qū)別?
1,進(jìn)程:子進(jìn)程是父進(jìn)程的復(fù)制品。子進(jìn)程獲得父進(jìn)程數(shù)據(jù)空間、堆和棧的復(fù)制品。
2,線程:相對與進(jìn)程而言,線程是一個更加接近與執(zhí)行體的概念,它可以與同進(jìn)程的其他
線程共享數(shù)據(jù),但擁有自己的??臻g,擁有獨(dú)立的執(zhí)行序列。
兩者都可以提高程序的并發(fā)度,提高程序運(yùn)行效率和響應(yīng)時間。
線程和進(jìn)程在使用上各有優(yōu)缺點(diǎn):線程執(zhí)行開銷小,但不利于資源管理和保護(hù);而進(jìn)程正
相反。同時,線程適合于在SMP機(jī)器上運(yùn)行,而進(jìn)程則可以跨機(jī)器遷移。
思科
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ù)重復(fù)一次。寫一個函數(shù),找出被重復(fù)的數(shù)字
.時間復(fù)雜度必須為o(N)函數(shù)原型:
注意a[N]中存放的是1-〉N-1個數(shù)
int do_dup(int a[],int N)
{
int temp[N]={0};
for(int i=0;i<N;i++)
if(temp[a[i]]!=0)
return i;
}
3 一語句實現(xiàn)x是否為2的若干次冪的判斷
int i = 512;
cout << boolalpha << ((i & (i - 1)) ? false : true) << endl;
按位與運(yùn)算符a&b,對b中為1的位如果a中也為1則保留,a中其余位全部置0,剩下的a即為結(jié)果
也可以理解為保留a中與b中位1對應(yīng)的位,其余置0
其余按位運(yùn)算符類似,將a與b按位做相應(yīng)運(yùn)算,所得值即結(jié)果
4.unsigned int intvert(unsigned int x,int p,int n)實現(xiàn)對x的進(jìn)行轉(zhuǎn)換,p為起始轉(zhuǎn)化
位,n為需要轉(zhuǎn)換的長度,假設(shè)起始點(diǎn)在右邊.如x=0b0001 0001,p=4,n=3轉(zhuǎn)換后x=0b0110 00
01
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包含n個1
_t = _t << p;//將n個1左移p位
x ^= _t;
return x;
}
慧通:
什么是預(yù)編譯
何時需要預(yù)編譯:
1、總是使用不經(jīng)常改動的大型代碼體。
2、程序由多個模塊組成,所有模塊都使用一組標(biāo)準(zhǔn)的包含文件和相同的編譯選項。在這
種情況下,可以將所有包含文件預(yù)編譯為一個預(yù)編譯頭。
char * const p;
char const * p
const char *p
上述三個有什么區(qū)別?
char * const p; //常量指針,p的值不可以修改
char const * p;//指向常量的指針,指向的常量值不可以改
const char *p; //和char const *p
char str1[] = "abc";
char str2[] = "abc";
const char str3[] = "abc";
const char str4[] = "abc";
const char *str5 = "abc";
const char *str6 = "abc";
char *str7 = "abc";
char *str8 = "abc";
cout << ( str1 == str2 ) << endl;
cout << ( str3 == str4 ) << endl;
cout << ( str5 == str6 ) << endl;
cout << ( str7 == str8 ) << endl;
結(jié)果是:0 0 1 1
解答:str1,str2,str3,str4是數(shù)組變量,它們有各自的內(nèi)存空間;
而str5,str6,str7,str8是指針,它們指向相同的常量區(qū)域。
12. 以下代碼中的兩個sizeof用法有問題嗎?[C易]
void UpperCase( char str[] ) // 將 str 中的小寫字母轉(zhuǎn)換成大寫字母
{
for( size_t i=0; i<sizeof(str)/sizeof(str[0]); ++i )//sizeof(str)=4,為指針大小
if( 'a'<=str[i] && str[i]<='z' )
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -