《嵌入式C语言编程.ppt》由会员分享,可在线阅读,更多相关《嵌入式C语言编程.ppt(26页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、NanGuanEmbeddedSystemLabSchoolofInformationScienceandEngineeringNortheasternUniversityMemory 2005-10-7Declaration以下涉及内容未必对所有的嵌入式系统以下涉及内容未必对所有的嵌入式系统都适用。都适用。只针对共性问题进行探讨只针对共性问题进行探讨所举例子仅为示意所举例子仅为示意MemoryVolatile关键字关键字Thevolatilekeywordisatypequalifierusedtodeclarethatanobjectcanbemodifiedintheprogrambys
2、omethingotherthanstatements,suchastheoperatingsystem,thehardware,oraconcurrentlyexecutingthread.定义存储器映射寄存器时,必须使用定义存储器映射寄存器时,必须使用volatile关键字。关键字。#defineSCI_01*(volatileunsignedint*)0 x5808MemoryObjectsdeclaredasvolatilearenotusedinoptimizationsbecausetheirvaluecanchangeatanytime.Thesystemalwaysreadst
3、hecurrentvalueofavolatileobjectatthepointitisrequested,evenifthepreviousinstructionaskedforavaluefromthesameobject.Also,thevalueoftheobjectiswrittenimmediatelyonassignment.While(SCI_01=0);tempVarInt=RXBUF;MemoryOneuseofthevolatilequalifieristoprovideaccesstomemorylocationsusedbyasynchronousprocesses
4、suchasinterrupthandlers.intmain(void)while(1)if(i)dosomething();/*Interruptserviceroutine.*/interruptvoidISR_2(void)i=1;Memory栈和堆栈和堆C语言中的存储区域:语言中的存储区域:1.全局变量区:程序开始分配,程序结束释放全局变量区:程序开始分配,程序结束释放2.常量区:程序开始分配,程序结束释放常量区:程序开始分配,程序结束释放3.堆:程序员分配释放堆:程序员分配释放4.栈:编译器自动分配释放栈:编译器自动分配释放Memoryint a=0;/全局初始化区 char*p1
5、;/全局未初始化区 main()int b;/栈 char s =abc;/栈 char*p2;/栈 char*p3=123456;/1234560在常量区,p3在栈上。static int c=0;/全局(静态)初始化区 p1=(char*)malloc(10);p2=(char*)malloc(20);/分配得来得10和20字节的区域在堆区。strcpy(p1,123456);/1234560放在常量区,编译器可能会将它与p3所指向的123456优化成一块。Memory栈是系统提供的数据结构,是栈是系统提供的数据结构,是C程序运行程序运行的基础的基础任何系统都提供栈指针寄存器任何系统都提供
6、栈指针寄存器通过栈实现程序跳转等基本程序操作通过栈实现程序跳转等基本程序操作一个未经任何初始化的程序一个未经任何初始化的程序main()subFunc(i);执行时会出现问题?执行时会出现问题?Memory硬件堆栈与软件堆栈硬件堆栈与软件堆栈硬件堆栈硬件堆栈 当当CPU进入子程序或进入中断服务程序时,返回地进入子程序或进入中断服务程序时,返回地址被自动压入硬件堆栈址被自动压入硬件堆栈软件堆栈软件堆栈 函数的参数是通过软件堆栈传递的函数的参数是通过软件堆栈传递的,函数的出口地址存放在软件堆栈里函数的出口地址存放在软件堆栈里,函数用到的局部变量也是在软件堆栈里分配的函数用到的局部变量也是在软件堆栈
7、里分配的.都是必须的都是必须的MemoryPOP&PUSHPUSH把累加器的内容复制到堆栈顶部把累加器的内容复制到堆栈顶部POP指令把堆栈顶部的数值复制到累加器指令把堆栈顶部的数值复制到累加器POPD&PSHDPSHD把数据存储器的值压入软件堆栈顶部把数据存储器的值压入软件堆栈顶部POPD指令把数值从软件堆栈顶部弹出至数据存储器指令把数值从软件堆栈顶部弹出至数据存储器软件压栈与弹栈软件压栈与弹栈SP+SPMemoryvoid main(void)void main(void)unsigned unsigned intint i;i;Test(2,10);Test(2,10);intint Te
8、st(Test(intint i,i,intint j)j)intint temp;temp;temp=0;temp=0;return temp;return temp;AADD#-3,SP AADD#-3,SP MOV T1,*SP(#01h)MOV T1,*SP(#01h)MOV T0,*SP(#00h)MOV T0,*SP(#00h)MOV#0,*SP(#02h)MOV#0,*SP(#02h)MOV MOV AR1,*SP(#02h)AR1,*SP(#02h)MOV AR1,T0MOV AR1,T0AADD#3,SP AADD#3,SP RETRETMOV#10,T1MOV#10,T1M
9、OV#2,T0MOV#2,T0CALL TestCALL TestAADD#-4,SP AADD#-4,SP POPD*SP(#00h)POPD*SP(#00h)MOV T1,*SP(#02h)MOV T1,*SP(#02h)MOV T0,*SP(#01h)MOV T0,*SP(#01h)MOV#0,*SP(#03h)MOV#0,*SP(#03h)MOV MOV AR1,*SP(#03h)AR1,*SP(#03h)MOV AR1,T0MOV AR1,T0PSHD*SP(#00h)PSHD*SP(#00h)AADD#3,SP AADD#3,SP RETRETMOV#10,T1MOV#10,T1M
10、OV#2,T0MOV#2,T0CALL TestCALL TestMemoryvoid main(void)void main(void)unsigned unsigned intint i;i;interruptinterrupt void Test()void Test()intint temp;temp;temp=0;temp=0;return;return;AADD#-1,SP AADD#-1,SP MOV#0,*SP(#00h)MOV#0,*SP(#00h)AADD#1,SP AADD#1,SP RETRETMemory堆是由堆是由C函数库提供的数据结构函数库提供的数据结构由由mal
11、loc()、realloc()产生产生使用后要使用后要free()掉掉堆的数据结构是怎样的?堆的数据结构是怎样的?Memory#defineNULL0#defineMEMSIZE(1024*8)typedefdoubleAlign;typedefunionheaderstructunionheader*next;unsignedusedsize;unsignedfreesize;s;Aligna;Header;staticHeadermem=mem,1,MEMSIZE1;staticHeader*memptr=mem;voidfree(void*ap)Header*bp,*p,*prev;bp
12、=(Header*)ap-1;for(prev=memptr,p=memptr-s.next;(p!=bp)&(p!=memptr);prev=p,p=p-s.next);if(p=bp)prev-s.freesize+=p-s.usedsize+p-s.freesize;prev-s.next=p-s.next;memptr=prev;void*malloc(unsignednbytes)Header*p,*newp;unsignednunits;nunits=(nbytes+sizeof(Header)-1)/sizeof(Header)+1;for(p=memptr;(p-s.next!
13、=memptr)&(p-s.freesizes.next);if(p-s.freesizes.usedsize;newp-s.usedsize=nunits;newp-s.freesize=p-s.freesize-nunits;newp-s.next=p-s.next;p-s.freesize=0;p-s.next=newp;memptr=newp;return(void*)(newp+1);Memory高效地使用堆高效地使用堆Example:如何动态定义二维数组?如何动态定义二维数组?Memorymain()inttemp;intn,m;int*a;a=(int*)malloc(sizeof(int)*n*m);aij=temp;return(1);Memorymain()inttemp;inti,n,m;int*a;a=(int*)malloc(sizeof(int*),n);for(i=0;in;i+)ai=(int*)malloc(sizeof(int),m);aij=temp;return(1);Memoryadd3add2add1mainsub1sub2sub3add1add2add3BackMemoryadd3mainsub1sub2sub3add1add2add3add1add2add3Back
限制150内