书签 分享 收藏 举报 版权申诉 / 26
上传文档赚钱

类型嵌入式C语言编程课件.ppt

  • 上传人(卖家):晟晟文业
  • 文档编号:4380488
  • 上传时间:2022-12-04
  • 格式:PPT
  • 页数:26
  • 大小:236KB
  • 【下载声明】
    1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
    2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
    3. 本页资料《嵌入式C语言编程课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
    4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
    5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
    配套讲稿:

    如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。

    特殊限制:

    部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。

    关 键  词:
    嵌入式 语言 编程 课件
    资源描述:

    1、Nan GuanEmbedded System LabSchool of Information Science and Engineering Northeastern University Memory 2005-10-7Declaration 以下涉及内容未必对所有的嵌入式系统以下涉及内容未必对所有的嵌入式系统都适用。都适用。只针对共性问题进行探讨只针对共性问题进行探讨 所举例子仅为示意所举例子仅为示意Memory Volatile关键字关键字The volatile keyword is a type qualifier used to declare that an object c

    2、an be modified in the program by something other than statements,such as the operating system,the hardware,or a concurrently executing thread.定义存储器映射寄存器时,必须使用定义存储器映射寄存器时,必须使用volatile关键字。关键字。#define SCI_01 *(volatile unsigned int*)0 x5808MemoryObjects declared as volatile are not used in optimization

    3、s because their value can change at any time.The system always reads the current value of a volatile object at the point it is requested,even if the previous instruction asked for a value from the same object.Also,the value of the object is written immediately on assignment.While(SCI_01=0);tempVarIn

    4、t=RXBUF;MemoryMemoryOne use of the volatile qualifier is to provide access to memory locations used by asynchronous processes such as interrupt handlers.int main(void)while(1)if(i)dosomething();/*Interrupt service routine.*/interrupt void ISR_2(void)i=1;Memory 栈和堆栈和堆C语言中的存储区域:语言中的存储区域:1.全局变量区:程序开始分配

    5、,程序结束释放全局变量区:程序开始分配,程序结束释放2.常量区:程序开始分配,程序结束释放常量区:程序开始分配,程序结束释放3.堆:程序员分配释放堆:程序员分配释放4.栈:编译器自动分配释放栈:编译器自动分配释放Memory int a=0;/全局初始化区 char*p1;/全局未初始化区 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和2

    6、0字节的区域在堆区。strcpy(p1,123456);/1234560放在常量区,编译器可能会将它与p3所指向的123456优化成一块。Memory 栈是系统提供的数据结构,是栈是系统提供的数据结构,是C程序运行程序运行的基础的基础任何系统都提供栈指针寄存器任何系统都提供栈指针寄存器通过栈实现程序跳转等基本程序操作通过栈实现程序跳转等基本程序操作一个未经任何初始化的程序一个未经任何初始化的程序main()subFunc(i);执行时会出现问题?执行时会出现问题?Memory 硬件堆栈与软件堆栈硬件堆栈与软件堆栈硬件堆栈硬件堆栈 当当CPU进入子程序或进入中断服务程序时,返回地进入子程序或进入

    7、中断服务程序时,返回地址被自动压入硬件堆栈址被自动压入硬件堆栈软件堆栈软件堆栈 函数的参数是通过软件堆栈传递的函数的参数是通过软件堆栈传递的,函数的出口地址存放在软件堆栈里函数的出口地址存放在软件堆栈里,函数用到的局部变量也是在软件堆栈里分配的函数用到的局部变量也是在软件堆栈里分配的.都是必须的都是必须的Memory POP&PUSH PUSH把累加器的内容复制到堆栈顶部把累加器的内容复制到堆栈顶部 POP指令把堆栈顶部的数值复制到累加器指令把堆栈顶部的数值复制到累加器 POPD&PSHD PSHD把数据存储器的值压入软件堆栈顶部把数据存储器的值压入软件堆栈顶部 POPD指令把数值从软件堆栈顶

    8、部弹出至数据存储器指令把数值从软件堆栈顶部弹出至数据存储器 软件压栈与弹栈软件压栈与弹栈 SP+SPMemoryvoid main(void)void main(void)unsigned unsigned intint i;i;Test(2,10);Test(2,10);intint Test(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,MOV T1,*SP(#01h)SP(#01h)MOV T0,MOV T0,*S

    9、P(#00h)SP(#00h)MOV#0,MOV#0,*SP(#02h)SP(#02h)MOV MOV AR1,AR1,*SP(#02h)SP(#02h)MOV AR1,T0MOV AR1,T0AADD#3,SP AADD#3,SP RETRETMOV#10,T1MOV#10,T1MOV#2,T0MOV#2,T0CALL TestCALL TestAADD#-4,SP AADD#-4,SP POPD POPD*SP(#00h)SP(#00h)MOV T1,MOV T1,*SP(#02h)SP(#02h)MOV T0,MOV T0,*SP(#01h)SP(#01h)MOV#0,MOV#0,*SP

    10、(#03h)SP(#03h)MOV MOV AR1,AR1,*SP(#03h)SP(#03h)MOV AR1,T0MOV AR1,T0PSHD PSHD*SP(#00h)SP(#00h)AADD#3,SP AADD#3,SP RETRETMOV#10,T1MOV#10,T1MOV#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

    11、;temp=0;return;return;AADD#-1,SP AADD#-1,SP MOV#0,MOV#0,*SP(#00h)SP(#00h)AADD#1,SP AADD#1,SP RETRETMemory 堆是由堆是由C函数库提供的数据结构函数库提供的数据结构由由malloc()、realloc()产生产生使用后要使用后要free()掉掉堆的数据结构是怎样的?堆的数据结构是怎样的?Memory#define NULL 0#define MEMSIZE(1024*8)typedef double Align;typedef union header struct union header*

    12、next;unsigned usedsize;unsigned freesize;s;Align a;Header;static Header mem=mem,1,MEMSIZE 1;static Header*memptr=mem;voidfree(void*ap)Header*bp,*p,*prev;bp=(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.n

    13、ext=p-s.next;memptr=prev;void*malloc(unsigned nbytes)Header*p,*newp;unsigned nunits;nunits=(nbytes+sizeof(Header)-1)/sizeof(Header)+1;for(p=memptr;(p-s.next!=memptr)&(p-s.freesize s.next);if(p-s.freesize s.usedsize;newp-s.usedsize=nunits;newp-s.freesize=p-s.freesize-nunits;newp-s.next=p-s.next;p-s.f

    14、reesize=0;p-s.next=newp;memptr=newp;return(void*)(newp+1);Memory 高效地使用堆高效地使用堆Example:如何动态定义二维数组?如何动态定义二维数组?Memorymain()int temp;int n,m;int*a;a=(int*)malloc(sizeof(int)*n*m);aij=temp;return(1);Memorymain()int temp;int i,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

    展开阅读全文
    提示  163文库所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
    关于本文
    本文标题:嵌入式C语言编程课件.ppt
    链接地址:https://www.163wenku.com/p-4380488.html

    Copyright@ 2017-2037 Www.163WenKu.Com  网站版权所有  |  资源地图   
    IPC备案号:蜀ICP备2021032737号  | 川公网安备 51099002000191号


    侵权投诉QQ:3464097650  资料上传QQ:3464097650
       


    【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。

    163文库