华为嵌入式面试题(4)

2020-05-03 18:07

{

char string[10];

char* str1=\ strcpy(string, str1); } 答:表面上并且编译都不会错误。但如果string数组原意表示的是字符串的话,那这个赋值就没有达到意图。最好定义为char string[11],这样最后一个元素可以存储字符串结尾符'\\0'; void test2() { char string[10], str1[10]; for(int I=0; I <10;I++) { str1[I] ='a'; } strcpy(string, str1); } 答:strcpy使用错误,strcpy只有遇到字符串末尾的'\\0'才会结束,而str1并没有结尾标志,导致strcpy函数越界访问,不妨让str1[9]='\\0',这样就正常了。 void test3(char* str1) { char string[10]; if(strlen(str1) <=10) { strcpy(string, str1); } } 答:这又会出现第一道改错题的错误了。strlen(str1)算出来的值是不包含结尾符'\\0'的,如果str1刚好为10个字符+1结尾符,string就得不到结尾符了。可将strlen(str1) <=10改为strlen(str1) <10。 2. 找错

#define MAX_SRM 256 DSN get_SRM_no() { static int SRM_no;

int I;

for(I=0;I

SRM_no%=MAX_SRM; if(MY_SRM.state==IDLE) { break; } }

if(I>=MAX_SRM)

return (NULL_SRM); else

return SRM_no;

} 答:我不知道这段代码的具体功能,但明显有两个错误 1,SRM_no没有赋初值 2,由于static的声明,使该函数成为不可重入(即不可预测结果)函数,因为SRM_no变量放在程序的全局存储区中,每次调用的时候还可以保持原来的赋值。这里应该去掉static声明。 3. 写出程序运行结果 int sum(int a) {

auto int c=0; static int b=3; c+=1; b+=2;

return(a+b+c);

}

void main() {

int I; int a=2;

for(I=0;I <5;I++) {

printf(\ }

} 答:8,10,12,14,16 该题比较简单。只要注意b声明为static静态全局变量,其值在下次调用时是可以保持住原来的赋值的就可以。 4. int func(int a) {

int b; switch(a) {

case 1: b=30; case 2: b=20; case 3: b=16; default: b=0; } return b; } 则func(1)=?

答:func(1)=0,因为没有break语句,switch中会一直计算到b=0。这是提醒我们不要忘了break。呵呵。 5:

int a[3]; a[0]=0; a[1]=1; a[2]=2; int *p, *q; p=a; q=&a[2]; 则a[q-p]=?

答:a[q-p]=a[2]=2;这题是要告诉我们指针的运算特点 6. 定义 int **a[3][4], 则变量占有的内存空间为:_____

答:此处定义的是指向指针的指针数组,对于32位系统,指针占内存空间4字节,因此总空间为3×4×4=48。

7. 编写一个函数,要求输入年月日时分秒,输出该年月日时分秒的下一秒。如输入2004年12月31日23时59分59秒,则输出2005年1月1日0时0分0

秒。

答: /*输入年月日时分秒,输出年月日时分秒的下一秒,输出仍然在原内存空间*/

void NextMinute(int *nYear,int *nMonth,int *nDate,int *nHour,int *nMinute,int *nSecond) {

int nDays;

(*nSecond)++; // 秒加1

if(*nSecond>=60) // 秒满60,做出特殊处理,下面时,日,月等类同 {

*nSecond=0; (*nMinute)++; if(*nMinute>=60) {

*nMinute=0; (*nHour)++; if(*nHour>=24) {

*nHour=0; (*nDate)++; switch(*nMonth) {

case 1: case 3: case 5: case 7: case 8: case 10: case 12: nDays=31;

break;

case 2:// 判断闰年

if(*nYear@0==0||*nYear0!=0&&*nYear%4==0) {

nDays=29; } else {

nDays=28; } break; default:

nDays=30; break;

}

if(*nDate>nDays) {

*nDate=1; (*nMonth)++; if(*nMonth>12) {

*nMonth=1; (*nYear)++; } } } } }

} /*示例可运行代码*/ Void main() {

int nYear=2004,nMonth=12,nDate=31,nHour=59,nMinute=59,nSecond=59; NextMinute(&nYear,&nMonth,&nDate,&nHour,&nMinute,&nSecond);

printf(\ear,nMonth,nDate,nHour,nMinute,nSecond); }

一、 研发(软件)

用C语言写一个递归算法求N!;

给一个C的函数,关于字符串和数组,找出错误; 防火墙是怎么实现的? 你对哪方面编程熟悉?

硬件:

1、继电器控制电路。 2、SDRAM是怎么工作的

3、写出逻辑表达式说明A2A1A0大于B2B1B0。 4、常用触发器有几种

5、示波器有几种触发方式,举出三种

18 IP 包头几个字节?加上数据部分几个字节

答案:应该是问IPV4,一般20字节,加上源路由选择等后最大60字节,加上数据部分还是根据链路MTU决定

IP包头多少个字节?


华为嵌入式面试题(4).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:14、(彭长盛)2017年中考题解析 - 名著阅读(含文段阅读)

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: