華為嵌入式工程師面試題試題及答案
(1)什么是預(yù)編譯,何時(shí)需要預(yù)編譯:
答案:
1、總是使用不經(jīng)常改動(dòng)的大型代碼體。
2、程序由多個(gè)模塊組成,所有模塊都使用一組標(biāo)準(zhǔn)的包含文件和相同的編譯選項(xiàng)。在這種情況下,可以將所有包含文件預(yù)編譯為一個(gè)預(yù)編譯頭。
(2)char * const p char const * p const char *p 上述三個(gè)有什么區(qū)別?
答案:
char * const p; //常量指針,p的值不可以修改
char const * p;//指向常量的指針,指向的常量值不可以改
const char *p; //和char const *p
(3)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 ) < < p>
結(jié)果是:0 0 1 1 str1,str2,str3,str4是數(shù)組變量,它們有各自的內(nèi)存空間;而str5,str6,str7,str8是指針,它們指向相同的常量區(qū)域。
(4)以下代碼中的兩個(gè)sizeof用法有問題嗎?
[C易] void UpperCase( charstr[] ) // 將 str 中的小寫字母轉(zhuǎn)換成大寫字母 { for( size_t i=0; i< endl; <="str[i]" str< cout ); str UpperCase( sizeof(str[0])
(5)一個(gè)32位的機(jī)器,該機(jī)器的指針是多少位答案:
指針是多少位只要看地址總線的位數(shù)就行了。80386以后的機(jī)子都是32的數(shù)據(jù)總線。所以指針的位數(shù)就是4個(gè)字節(jié)了。
6、main() { inta[5]={1,2,3,4,5}; int *ptr=(int*)(&a+1); printf("%d,%d",*(a+1),*(ptr-1)); }
答案:2。5 *(a+1)就是a[1],*(ptr-1)就是a[4],執(zhí)行結(jié)果是2,5 &a+1不是首地址+1,系統(tǒng)會(huì)認(rèn)為加一個(gè)a數(shù)組的偏移,是偏移了一個(gè)數(shù)組的大小(本例是5個(gè)int) int *ptr=(int*)(&a+1); 則ptr實(shí)際是&(a[5]),也就是a+5 原因如下: &a是數(shù)組指針,其類型為 int (*)[5]; 而指針加1要根據(jù)指針類型加上一定的值,不同類型的指針+1之后增加的大小不同 a是長(zhǎng)度為5的int數(shù)組指針,所以要加 5*sizeof(int) 所以ptr實(shí)際是a[5] 但是prt與(&a+1)類型是不一樣的(這點(diǎn)很重要) 所以prt-1只會(huì)減去sizeof(int*) a,&a的地址是一樣的,但意思不一樣,a是數(shù)組首地址,也就是a[0]的地址,&a是對(duì)象(數(shù)組)首地址,a+1是數(shù)組下一元素的地址,即a[1],&a+1是下一個(gè)對(duì)象的.地址,即a[5].
7、請(qǐng)問以下代碼有什么問題:
int main()
{
char a;
char *str=&a;
strcpy(str,"hello");
printf(str);
return 0;
}
答案:沒有為str分配內(nèi)存空間,將會(huì)發(fā)生異常問題出在將一個(gè)字符串復(fù)制進(jìn)一個(gè)字符變量指針?biāo)傅刂贰km然可以正確輸出結(jié)果,但因?yàn)樵浇邕M(jìn)行內(nèi)在讀寫而導(dǎo)致程序崩潰。
8、char* s="AAA"; printf("%s",s); s[0]='B';printf("%s",s); 有什么錯(cuò)?
答案:"AAA"是字符串常量。s是指針,指向這個(gè)字符串常量,所以聲明s的時(shí)候就有問題。 cosnt char*s="AAA"; 然后又因?yàn)槭浅A浚詫?duì)是s[0]的賦值操作是不合法的。
9、寫一個(gè)"標(biāo)準(zhǔn)"宏,這個(gè)宏輸入兩個(gè)參數(shù)并返回較小的一個(gè)。
答案:.#define Min(X, Y)((X)>(Y)?(Y):(X)) //結(jié)尾沒有';'
10、嵌入式系統(tǒng)中經(jīng)常要用到無(wú)限循環(huán),你怎么用C編寫死循環(huán)。
答案:while(1){}或者for(;;)
11、關(guān)鍵字static的作用是什么?
答案:定義靜態(tài)變量
12、關(guān)鍵字const有什么含意?
答案:表示常量不可以修改的變量。
13、關(guān)鍵字volatile有什么含意?并舉出三個(gè)不同的例子?
答案:提示編譯器對(duì)象的值可能在編譯器未監(jiān)測(cè)到的情況下改變。
14、int(*s[10])(int) 表示的是什么啊?
答案:int(*s[10])(int) 函數(shù)指針數(shù)組,每個(gè)指針指向一個(gè)int func(int param)的函數(shù)。
15、有以下表達(dá)式:
int a=248;
b=4;
int const c=21;
const int *d=&a;
int *conste=&b;
int const *f const =&a;
請(qǐng)問下列表達(dá)式哪些會(huì)被編譯器禁止?為什么?
答案:*c=32;d=&b;*d=43;e=34;e=&a;f=0x321f;*c 這是個(gè)什么東東,禁止 *d 說(shuō)了是const, 禁止 e = &a 說(shuō)了是const 禁止 const *f const =&a; 禁止
16、交換兩個(gè)變量的值,不使用第三個(gè)變量。即a=3,b=5,交換之后a=5,b=3;
答案:有兩種解法, 一種用算術(shù)算法, 一種用^(異或) a = a + b; b = a - b; a= a - b; or a = a^b;// 只能對(duì)int,char.. b = a^b; a = a^b; or a ^= b ^= a;
17.c和c++中的struct有什么不同?
答案:c和c++中struct的主要區(qū)別是c中的struct不可以含有成員函數(shù),而c++中的struct可以。c++中struct和class的主要區(qū)別在于默認(rèn)的存取權(quán)限不同,struct默認(rèn)為public,而class默認(rèn)為private
18.
#include
#include
void getmemory(char *p)
{
p=(char *)malloc(100);
strcpy(p,"helloworld");
}
int main( )
{
char *str=NULL;
getmemory(str);
printf("%s/n",str);
free(str);
return 0;
}
答案:程序崩潰,getmemory中的malloc 不能返回動(dòng)態(tài)內(nèi)存, free()對(duì)str操作很危險(xiǎn)
19.
char szstr[10];
strcpy(szstr,"0123456789"); 產(chǎn)生什么結(jié)果?為什么?
答案: 長(zhǎng)度不一樣,會(huì)造成非法的OS
20.列舉幾種進(jìn)程的同步機(jī)制,并比較其優(yōu)缺點(diǎn)。
答案: 原子操作 信號(hào)量機(jī)制 自旋鎖 管程,會(huì)合,分布式系統(tǒng)
【華為嵌入式工程師面試題試題及答案】相關(guān)文章:
2016嵌入式工程師面試題及答案「精選」09-24
嵌入式面試題及答案「C語(yǔ)言」08-02
2016年嵌入式面試題及答案11-12
2016最新嵌入式面試題及答案09-10
2016年華為筆試面試題及答案11-09
2016年公司嵌入式面試題及答案09-03
Java工程師面試題及答案09-16