微信掃一掃
名企業(yè)面試題及答案匯總
華為面試題及答案
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)容
以下是引用片段:
#include
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
7、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)有效, 在同一源程序的其它源文件中不能 IT人才網(wǎng)(http://it.ad0.cn) 使用它。由于靜態(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)用中維持一份拷貝
8、程序的局部變量存在于(堆棧)中,全局變量存在于(靜態(tài)區(qū) )中,動態(tài)申請數(shù)據(jù)存在于( 堆)中。
9、設有以下說明和定義:
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
10、隊列和棧有什么區(qū)別
隊列先進先出,棧后進先出
11、寫出下列代碼的輸出內(nèi)容
以下是引用片段:
#include
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
12、請找出下面代碼中的所以錯誤
說明:以下代碼是把一個字符串倒序,如“abcd”倒序后變?yōu)?ldquo;dcba”
以下是引用片段:
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);// 使用完,應當釋放空間,以免造成內(nèi)存匯泄露
return 0;
}
方法2:
以下是引用片段:
#include
#include
main()
{
char str[]="hello,world";
int len=strlen(str);
char t;
for(int i=0; i
{
t=str;
str=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);
程序例:
以下是引用片段:
#include
#include
int main(void)
{
long l;
char *str = "98765432";
l = atol(lstr);
printf("string = %s integer = %ld\n", str, l);
return(0);
}
13.對于一個頻繁使用的短小函數(shù),在C語言中應用什么實現(xiàn),在C++中應用什么實現(xiàn)
c用宏定義,c++用inline
14.直接鏈接兩個信令點的一組鏈路稱作什么
PPP點到點連接
15.接入網(wǎng)用的是什么接口
16.voip都用了那些協(xié)議
17.軟件測試都有那些種類
黑盒:針對系統(tǒng)功能的測試
白合:測試函數(shù)功能,各函數(shù)接口
18.確定模塊的功能和模塊的接口是在軟件設計的那個隊段完成的
概要設計階段
19.
enum string
{x1,x2,x3=10,x4,x5,}x;
問x= 0x801005,0x8010f4 ;
20.
unsigned char *p1;
unsigned long *p2;
p1=(unsigned char *)0x801000;
p2=(unsigned long *)0x810000;
請問p1+5= ;
p2+5= ;
選擇題:
21.Ethternet鏈接到Internet用到以下那個協(xié)議
A.HDLC;B.ARP;C.UDP;D.TCP;E.ID
22.屬于網(wǎng)絡層協(xié)議的是:
A.TCP;B.IP;C.ICMP;D.X.25
23.Windows消息調(diào)度機制是:
A.指令隊列;B.指令堆棧;C.消息隊列;D.消息堆棧;
24.
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
找錯題:
-
上一條:時尚求職者面試成功的四大法寶
自定義HTML廣告位
名企招聘
-
山東魯興機動車檢測有限公司已認證
千泉街道 1 職位招聘中
-
甘茶度甜品飲料店已認證
5 職位招聘中
-
咖啡之翼品牌管理有限公司已認證
5 職位招聘中
-
北京悅容麗人整形已認證
4 職位招聘中
-
漢家星空酒店已認證
10 職位招聘中
-
創(chuàng)世影視文化有限公司已認證
0 職位招聘中
-
合肥一六三信息技術有限公司已認證
鋼山街道 3 職位招聘中
-
吉祥混沌已認證
城區(qū) 0 職位招聘中
-
鏈家房地產(chǎn)有限公司已認證
6 職位招聘中
-
花信美容體驗中心已認證
5 職位招聘中
置頂推薦
-
誠聘電腦操作員經(jīng)驗不限
2000-3000元技術支持
餐補全勤獎 -
誠聘營業(yè)員經(jīng)驗不限
3000-5000元營業(yè)員
-
誠聘銷售總監(jiān)經(jīng)驗不限
8000元以上銷售總監(jiān)
五險一金工作餐包吃包住 -
誠聘其他銷售經(jīng)驗不限
8000元以上其他銷售
五險一金工作餐包吃包住 -
誠聘美甲師、美睫師。環(huán)境舒適,每天客源穩(wěn)定。
2000-3000元美甲師
鄒城如一美甲美睫名企
最新工作
-
誠聘電腦操作員經(jīng)驗不限
2000-3000元技術支持
餐補全勤獎 -
誠聘營業(yè)員經(jīng)驗不限
3000-5000元營業(yè)員
-
誠聘銷售總監(jiān)經(jīng)驗不限
8000元以上銷售總監(jiān)
五險一金工作餐包吃包住 -
誠聘其他銷售經(jīng)驗不限
8000元以上其他銷售
五險一金工作餐包吃包住 -
誠聘美甲師、美睫師。環(huán)境舒適,每天客源穩(wěn)定。
2000-3000元美甲師
鄒城如一美甲美睫名企
急聘工作
-
誠聘電腦操作員經(jīng)驗不限
2000-3000元技術支持
餐補全勤獎 -
日結裝卸工叉車司機學徒工押車工包吃住長短期
8000元以上裝卸工
帶薪年假年終獎工作餐 -
誠聘教師經(jīng)驗2年以上
2000-3000元教師
五險一金工作餐全勤獎藍衫樹雙語幼兒園名企
-
誠聘網(wǎng)站運營 經(jīng)驗5年以上
5000-8000元網(wǎng)站運營
帶薪年假包吃包住年終分紅 -
誠聘客房服務經(jīng)驗2年以上
2000-3000元客房服務
餐補全勤獎彈性工作漢家星空酒店名企