嵌入式软件试题_第1页
嵌入式软件试题_第2页
嵌入式软件试题_第3页
嵌入式软件试题_第4页
嵌入式软件试题_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、姓名1.C语言的目标程序在运行环境下的存储空间大致分为目标代码区和数据区,数据区又分为全局/静态区域、栈(假设进程栈的最大值为1K)和堆;下图所示的是目标程序运行时环境一个简单和不是很严格的示意图,请举出程序中分别属于全局/静态区域、栈区和堆区变量的例子;并指出程序中的错误;还有要指明main函数执行那个分支(if.else.)(错误和答案可以以代码走查形式直接在程序中标出来,后面的问题相同处理)。constintMAX=1024;int*Sum(intiSumLValue,intiSumRValue)/计算两个数的和intiSum;iSum=iSumLValue+iSumRValue;ret

2、urn&iSum;voidSub(intiSubLValue,intiSubRValue)/计算两个数的差值staticintiSub;iSub=iSubLValue-iSubRValue;int*Mem()/分配内存int*pMen;pMen=malloc(sizeof(int)*MAX+1);*(pMen+MAX)=10;returnpMen;voidmain()intiIndex=0;intiNext=5;intarrMAX;memcpy(arr,Mem(),1+sizeof(int)*MAX);if(0=iNext&iNext=5)for(;iIndex=MAX;iIndex+)int

3、*pSum=Sum(*(arr+iIndex),*(arr+iIndex+1);printf(%dn,*pSum);elsefor(;iIndex=MAX;iIndex+)Sub(*(arr+iIndex),*(arr+iIndex+1);for(iIndex=0;iIndex=MAX;iIndex+)printf(%dn,*(long*)arr+iIndex);2.指出下面程序可能会发生的错误,程序执行时候需要输入两个参数,其中第1个参数表示第2个参数所表示字符串的长度。程序目的是将输入的字符串放入缓冲区(buf)中。#include#includeintmain(intargc,char*

4、argv)unsignedshortusLength;intiInput;charbuf0 xFFFF;if(argc0 xFFFF)/*w1*/return-1;memcpy(buf,argv2,iInput);bufusLength=0;return0;3指出下面程序的错误,函数Fun返回成功(SUCCESS)或者失败(FAILURE);其中else分支没有任何代码处理。函数LoopUp根据ucInputVar值在内存的数据结构中查找某种数据,返回查找成功或者失败。(BYTE定以为unsignedchar)#defineSUCCESS0#defineFAILURE1BYTEFun(BYTE

5、ucInputVar)BYTEucResult;/*定义函数返回值变量*/if(SUCCESS=LoopUp(ucInputVar)ucResult=SUCCESS;elsereturnucResult;4指出下面两段程序有什么样的区别。注:a和b都是int类型,而且都是非负数,判断语句目的是在异常情况下(a+b0)执行保护倒换操作;而且该程序运行环境下的CPU中存在一个寄存器,表示加法计算结果的状态,包括“正”,“负”,“零”和“溢出”状态。【1】if(a+b0)/执行保护倒换操作【2】if(int)(unsigned)a+(unsigned)b)0)/执行保护倒换操作指出下面程序的错误,修

6、改源程序,增加检测手段使得能够预防该问题出现#defineMAX60#defineNUM_SET50#defineSIZE10int*fun()intiSize=SIZE;return&iSize;voidmain()unsignedcharucIndex;unsignedcharaucSetInfoNUM_SET;for(ucIndex=0;ucIndexMAX;ucIndex+)aucSetInfoucIndex=aucSetInfoucIndex+1;for(ucIndex=0;ucIndex*fun();ucIndex+)aucSetInfoucIndex=aucSetInfoucIn

7、dex+1;指出下面程序的错误#defineSIZE5structStringchar*pData;voidmain()characValue1SIZE=H,E,L,L,O;characValue2SIZE=W,O,R,L,D;structStringa,b,c;a.pData=malloc(SIZE*sizeof(char);memcpy(a.pData,acValue1,SIZE);b.pData=malloc(SIZE*sizeof(char);memcpy(b.pData,acValue2,SIZE);b=a;free(a.pData);c=b;指出下面程序的错误,这样的错误会引起什么

8、后果,并将程序修正。嵌入式软件试题main()intloop=1;while(loop5)intarr1000;inti=0;for(;i=0;ucCount-)iCount+;9.指出下面程序的错误(函数GetValue返回unsignedchar类型的值)#defineMAXNUM400;unsignedcharucIndex,ucInputVar,aucArrayMAXNUM;for(ucIndex=0;ucIndex(ucInputVar-1);ucIndex+)aucArrayucIndex=aucArrayucIndex*2+1;10指出下面程序的错误,其中结构RetSize表示矩

9、形大小,用来表示窗口大小typedefstructRetSizeWORDlength;WORDwidth;voidmain()RetSizeszMin;/*定义最小窗口变量*/SetMinSize(&szMin);/*初始化(设定)最小窗口的长和宽*/SetWindowSize(&szMin);/*将当前窗口大小置为最小值*/科室姓名嵌入式软件试题11.指出下面程序中可能出现的溢出问题,这样的错误会引起什么样的后果。#defineMAX0 x40000000intmyfunction(intlen)int*myarray,i;myarray=malloc(len*sizeof(int);/*1

10、*/if(myarray=0)return-1;for(i=0;i0)response=malloc(nresp*sizeof(char*);for(i=0;inresp;i+)packet_get_string(response,i);指出下面程序由于符号问题可能引起的溢出问题,copymem函数主要完成从堆中拷贝一段内存到用户区。#defineMAX256char*copymem(intiLength)char*pMem=0;嵌入式软件试题if(iLengthMAX)/*1*/pMem=malloc(unsignedint)iLength);returnpMem;elsereturn0;v

11、oidmain()char*pMem;pMem=copymem(0 xffffffff);指出下面两段程序的区别【1】main()intloop=1;intarr10;inti=0;while(loop5)for(;i=10;i+)arri=1;loop+;【2】main()intarr10;intloop=1;inti=0;while(loop5)for(i=0;i=10;i+)arri=1;loop+;指出下面三个结构分别占用的字节数【1】typedefstructunsignedshortwItemOne;unsignedlongdwItemTwo;unsignedcharbItemThree;unsignedcharbItemFour;unsignedcharbItemFive;CPerf1;【2】#pragmapack(1)typedefstructunsignedshortwItemOne;unsignedlongdwItemTwo;unsignedcharbItemThree;unsignedcharbI

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论