PICCC语言基础和特点.ppt

上传人:小** 文档编号:23694369 上传时间:2021-06-10 格式:PPT 页数:114 大小:933.50KB
返回 下载 相关 举报
PICCC语言基础和特点.ppt_第1页
第1页 / 共114页
PICCC语言基础和特点.ppt_第2页
第2页 / 共114页
PICCC语言基础和特点.ppt_第3页
第3页 / 共114页
点击查看更多>>
资源描述
2021-6-5 Down Up Main Return 2021-6-5 Down Up Main Return 基于 PICC 编译环境编写 PIC 单片机C程序的基本方式和标准 C 程序类似,程序一般由以下几个主要部分组成:在程序的最前面用#include 预处理指令引用包含头文件,其中必须包含一个编译器提供的“pic.h”文件,实现单片机内特殊寄存器和其它特殊符号的声明; 2021-6-5 Down Up Main Return 用“_ _CONFIG”预处理指令定义芯片的配置位;声明本模块内被调用的所有函数的类型,PICC 将对所调用的函数进行严格的类型匹配检查; 定义全局变量或符号替换; 实现函数(子程序),特别注意 main 函数必须是一个没有返回的死循环。 2021-6-5 Down Up Main Return 下面的例子为一个C源程序的范例:#include/包含单片机内部资源预定义#include “pc68.h” /包含自定义头文件_ _CONFIG (HS /定义芯片工作时的配置位 2021-6-5 Down Up Main Return void SetSFR(void); void Clock(void); void KeyScan(void); void Measure(void); void LCD_Test(void); void LCD_Disp(unsigned char);/声明本模块中所调用的函数类型 2021-6-5 Down Up Main Return unsigned char second, minute, hour; bit flag1,flag2; /定义变量 void main(void) /函数和子程序 SetSFR( ); PORTC = 0 x00; TMR1H += TMR1H_CONST; LED1 = LED_OFF; LCD_Test( ); 2021-6-5 Down Up Main Return while(1) asm(“clrwdt”); /清看门狗 Clock(); /更新时钟 KeyScan(); /扫描键盘 Measure(); /数据测量 SetSFR(); /刷新特殊功能寄存器 / /程序工作主循环 2021-6-5 Down Up Main Return PICC不支持C+,这对于习惯了C+的同学还得翻翻C 语言的书。我们在源程序一开始使用了“#include”实现了相关单片机的一些预定义符号的直接引用,但没有具体指明是哪一个型号。 2021-6-5 Down Up Main Return 实际上,“pic.h”头文件是很多头文件的集合,是一个简单的管理工具(条件判别),它会按照MPLAB-IDE所选择的特定型号的单片机,把真正对应的头文件包含进来。也就是说:C 编译器在pic.h 中根据你的芯片自动载入相应的其它头文件,这点比汇编好用。 2021-6-5 Down Up Main Return 调用真正头文件调用真正头文件头文件用记事本打开 2021-6-5 Down Up Main Return 载入的头文件中其实是声明芯片的寄存器和一些函数,摘抄一个片段:例如:static volatile unsigned char TMR0 0 x01;static volatile unsigned char PCL 0 x02;static volatile unsigned char STATUS 0 x03; 2021-6-5 Down Up Main Return 可以看出和汇编的头文件中定义寄存器是差不多的。如下:TMR0 EQU 0X01;PCL EQU 0X02;STATUS EQU 0X03;都是把无聊的地址定义为大家公认的名字。 2021-6-5 Down Up Main Return 2.2.1 PICC 中 的 基 本 变 量 类 型 PICC编辑器支持基本的1,2及4B数据。所有多字节数据遵循Little-endian标准,多字节变量的低字节放在存储空间的低地址,高字节放在高地址下表中列出了PICC支持的数据类型及对应的大小和数学表达: 2021-6-5 Down Up Main Return Little-endian和 Big-endian是 表 示 计 算 机 字节 顺 序 的 两 种 格 式 。 简 单 的 说 , Little-endian把 低 字 节 存 放 在内 存 的 低 位 ; 而 Big-endian将 低 字 节 存 放在 内 存 的 高 位 。 现 在 主 流 的 CPU, Intel系 列 的 是 采 用 的Little-endian的 格 式 存 放 数 据 , 而 Motorola系 列 的 CPU采 用 的 是 Big-endian。 2021-6-5 Down Up Main Return表 2 1 PICC 的 基 本 变 量 类 型 2021-6-5 Down Up Main Return 2.2.2 PICC 中 的 高 级 变 量 基于表2-1的基本变量,除了bit型位变量外,PICC 完全支持数组、结构和联合等复合型高级变量,这和标准的C语言所支持的高级变量类型没有什么区别。例如:联合:union int_Byte unsigned char c2; unsigned int i; ; 2021-6-5 Down Up Main Return 数组:unsigned int data10;结构:struct commInData unsigned char inBuff8; unsigned char getPtr, putPtr; ; 2021-6-5 Down Up Main Return 为了使编译器产生最高效的机器码,PICC把单片机中数据寄存器的bank问题交由编程员自己管理,因此在定义用户变量时你必须自己决定这些变量具体放在哪一个bank中。 2021-6-5 Down Up Main Return 如果没有特别指明,所定义的变量将被定位在bank0,例如下面所定义的这些变量:unsigned char buffer32;bit flag1,flag2; float val8; 2021-6-5 Down Up Main Return 除了bank0内的变量声明时不需特殊处理外,定义在其它bank内的变量前面必须加上相应的bank序号,例如:bank1 unsigned char buffer32; /变量定位在bank1中bank2 bit flag1,flag2;/变量定位在bank2中bank3 bit float val8;/变量定位在bank3中 2021-6-5 Down Up Main Return 中档系列PIC单片机数据寄存器的一个bank大小为128字节,刨去前面若干字节的特殊功能寄存器区域,在C语言中某一bank内定义的变量字节总数不能超过可用RAM字节数。如果超过bank容量,在最后链接时会报错,大致信息如下: 2021-6-5 Down Up Main Return 2021-6-5 Down Up Main Return Error000 : Cant find 0 x12C words for psect rbss_1 in segment BANK1 链接器告诉你总共有0 x12C(300)个字节准备放到bank1中但bank1容量不够。显然,只有把一部分原本定位在bank1中的变量改放到其它bank中才能解决此问题。 2021-6-5 Down Up Main Return 虽然变量所在的bank定位必须由编程员自己决定,但在编写源程序时进行变量存取操作前无需再特意编写设定bank的指令,C编译器会根据所操作的对象自动生成对应bank设定的汇编指令;为避免频繁的bank切换以提高代码效率,尽量把实现同一任务的变量定位在同一个bank内; 2021-6-5 Down Up Main Return 如对 TMR0 附值,汇编中:MOVLW 200;MOVWF TMR0;当然得保证当前bank在0或2,不然会出错(如在bank1或3)。 2021-6-5 Down Up Main Return C语言中:TMR0=200;无论在任何bank都不会出错,可以看出来C是很直接了当的。并且最大好处是操作一个寄存器时候,不用考虑bank的问题,一切由C编译器自动完成。 2021-6-5 Down Up Main Return PICC把所有函数内部定义的auto型局部变量放在bank0。为节约宝贵的存储空间,它采用了一种被叫做“静态覆盖”的技术来实现局部变量的地址分配。 2021-6-5 Down Up Main Return 其大致的原理是:在编译器编译源代码时扫描整个程序中函数调用的嵌套关系和层次,算出每个函数中的局部变量字节数;然后为每个局部变量分配一个固定的地址,且按调用嵌套的层次关系各变量的地址可以相互重叠。 2021-6-5 Down Up Main Return 利用这一技术后所有的动态局部变量都可以按已知的固定地址进行直接寻址,但这时不能出现函数递归调用。PICC在编译时会严格检查递归调用问题并认为这是一个严重错误而立即终止编译过程。所有的局部变量将占用bank0的存储空间,因此用户自己定位在bank0内的变量字节数将受到一定的限制,在实际使用时需注意。 2021-6-5 Down Up Main Return bit型位变量只能是全局的或静态的。PICC将把定位在同一bank内的8个位变量合并成一个字节存放于一个固定地址。PIC单片机的位操作指令是非常高效的。因此,PICC在编译源代码时只要有可能,对普通变量的操作也将以最简单的位操作指令来实现。 2021-6-5 Down Up Main Return 假设一个字节变量tmp最后被定位在地址 0 x20,那么:tmp =0 x80 =bsf 0 x20,7tmp unsigned b1: 1; unsigned b2: 1; unsigned b3: 1; unsigned b4: 1; unsigned b5: 1; unsigned : 2; /最高两位保留 oneBit; unsigned char allBits; myFlag; 2021-6-5 Down Up Main Return 需要存取其中某一位时可以:myFlag.oneBit.b3=1; /b3 位置 1一次性将全部位清零时可以 :myFlag.allBits=0; /全部位变量清 0 2021-6-5 Down Up Main Return 汇编中的位操作是很容易的。在PICC中更简单。C的头文件中已经对所有可能需要位操作的寄存器的每一位都有定义名称:如:PORTA的每一个I/O口定义为:RA0、RA1、RA2、RA3、RA4、RA5 、RA6 、RA7 。 2021-6-5 Down Up Main Return 可以对其直接进行运算和附值。如:RA0=0;RA2=1;在汇编中是:BCF PORTA,0;BSF PORTA,2;可以看出两者是大同小异的,只是C中不需要考虑bank的问题。 2021-6-5 Down Up Main Return PICC中描述浮点数是以IEEE-754标准格式实现的。此标准下定义的浮点数为 32位长,在单片机中要用4个字节存储。为了节约单片机的数据空间和程序空间,PICC专门提供了一种长度为24位的截短型浮点数,它损失了浮点数的一点精度,但浮点运算的效率得以提高。 2021-6-5 Down Up Main Return 在程序中定义的float型标准浮点数的长度固定为24位,双精度double型浮点数一般也是24位长,但可以在程序编译选项中选择double型浮点数为32位,以提高计算的精度。一般控制系统中关心的是单片机的运行效率,因此在精度能够满足的前提下尽量选择24 位的浮点数运算。 2021-6-5 Down Up Main Return 首先必须强调,在用C语言写程序时变量一般由编译器和链接器最后定位,在写程序之时无需知道所定义的变量具体被放在哪个地址;除了bank必须声明,真正需要绝对定位的只是单片机中那些特殊功能寄存器; 2021-6-5 Down Up Main Return 而这些寄存器的地址定位在PICC编译环境所提供的头文件中已经实现,无需用户操心。编程员所要了解的只是PICC是如何定义这些特殊功能寄存器和其中的相关控制位的名称。 2021-6-5 Down Up Main Return 好在PICC的定义标准基本上按照芯片的数据手册中的名称描述进行,这样就秉承了变量命名的一贯性。一个变量绝对定位的例子如下:unsigned char tmpData 0 x20; /tmpData定位在地址0 x20 2021-6-5 Down Up Main Return PICC对绝对定位的变量不保留地址空间。换句话说,上面变量tmpData的地址是0 x20,但最后0 x20处完全有可能又被分配给了其它变量使用,这样就发生了地址冲突。因此针对变量的绝对定位要特别小心。 2021-6-5 Down Up Main Return 由此可见,在一般的程序设计中用户自定义的变量实在是没有绝对定位的必要。 如果需要,位变量也可以绝对定位。但必须遵循上面介绍的位变量编址的方式。 2021-6-5 Down Up Main Return 如果一个普通变量已经被绝对定位,那么此变量中的每个数据位就可以用下面的计算方式实现位变量指派:unsigned char tmpData 0 x20; /tmpData定位在地址0 x20 tmpData必须先被绝对定位,然后才能用下面的位变量定位方式: 2021-6-5 Down Up Main Return bit tmpBit0 tmpData*8+0;/tmpBit0对应于tmpData第0位bit tmpBit1 tmpData*8+1; /tmpBit1对应于tmpData第1位bit tmpBit2 tmpData*8+2; /tmpBit2对应于tmpData第2位 2021-6-5 Down Up Main Return extern 外部变量声明如果在一个C程序文件中要使用一些变量但其原型定义写在另外的文件中,那么在本文件中必须将这些变量声明成“extern”外部类型。 2021-6-5 Down Up Main Return 例如程序文件 code1.c 中有如下定义:bank1 unsigned char var1, var2; /定义了 bank1 中的两个变量在另外一个程序文件code2.c中要对上面定义的变量进行操作,则必须在程序的开头定义:extern bank1 unsigned char var1, var2; /声明位于 bank1 的外部变量 2021-6-5 Down Up Main Return volatile 易变型变量声明PICC中还有一个变量修饰词在普通的 C语言介绍中一般是看不到的,这就是关键词“volatile”。顾名思义,它说明了一个变量的值是会随机变化的,即使程序没有刻意对它进行任何赋值操作。 2021-6-5 Down Up Main Return 在单片机中,作为输入的I/O端口其内容将是随意变化的;在中断内被修改的变量相对主程序流程来讲也是随意变化的;很多特殊功能寄存器的值也将随着指令的运行而动态改变。 2021-6-5 Down Up Main Return 所有这种类型的变量必须将它们明确定义成“volatile”类型。例如:volatile unsigned char STATUS 0 x03;volatile bit commFlag; 2021-6-5 Down Up Main Return “volatile”类型定义在单片机的C语言编程中是如此的重要,是因为它可以告诉编译器的优化处理器这些变量是实实在在存在的,在优化过程中不能无故消除。 2021-6-5 Down Up Main Return 假定你的程序定义了一个变量并对其作了一次赋值,但随后就再也没有对其进行任何读写操作,如果是非volatile型变量,优化后的结果是这个变量将有可能被彻底删除以节约存储空间。 2021-6-5 Down Up Main Return 另外一种情形是在使用某一个变量进行连续的运算操作时,这个变量的值将在第一次操作时被复制到中间临时变量中,如果它是非volatile型变量,则紧接其后的其它操作将有可能直接从临时变量中取数以提高运行效率。 2021-6-5 Down Up Main Return 显然这样做后对于那些随机变化的参数就会出问题。只要将其定义成volatile类型后,编译后的代码就可以保证每次操作时直接从变量地址处取数。 2021-6-5 Down Up Main Return const 常数型变量声明如果变量定义前冠以“const”类型修饰,那么所有这些变量就成为常数,程序运行过程中不能对其修改。除了位变量,其它所有基本类型的变量或高级组合变量都将被存放在程序空间(ROM区)以节约数据存储空间。 2021-6-5 Down Up Main Return 显然,被定义在 ROM区的变量是不能再在程序中对其进行赋值修改的,这也是“const”的本来意义。实际上这些数据最终都将以“retlw”的指令形式存放在程序空间,但PICC会自动编译生成相关的附加代码从程序空间读取这些常数,编程员无需太多操心。 2021-6-5 Down Up Main Return 例如:const unsigned char name =“This is a demo”; /定义一个常量字符串 2021-6-5 Down Up Main Return persistent 非初始化变量声明 按照标准C语言的做法,程序在开始运行前首先要把所有定义的但没有预置初值的变量全部清零。PICC会在最后生成的机器码中加入一小段初始化代码来实现这一变量清零操作,且这一操作将在main函数被调用之前执行。 2021-6-5 Down Up Main Return 事实上一个单片机的控制系统有很多变量是不允许在程序复位后被清零的。为了达到这一目的,PICC提供了“persistent”修饰词以声明此类变量无需在复位时自动清零;编程员应该自己决定程序中的哪些变量是必须声明成“persistent”类型,而且须自己判断什么时候需要对其进行初始化赋值。 2021-6-5 Down Up Main Return 例如:persistent unsigned char hour,minute,second; /定义时分秒变量 2021-6-5 Down Up Main Return PICC中指针的基本概念和标准C语法没有太多的差别。但是在PIC单片机这一特定的架构上,指针的定义方式还是有几点需要特别注意: 2021-6-5 Down Up Main Return 指向 RAM 的指针 指向 ROM 常数的指针 指向函数的指针指针的类型修饰 2021-6-5 Down Up Main Return 指向 RAM 的指针 如果是汇编语言编程,实现指针寻址的方法肯定就是用FSR寄存器,PICC 也不例外。为了生成高效的代码,PICC在编译C源程序时将指向RAM的指针操作最终用FSR来实现间接寻址。 2021-6-5 Down Up Main Return 这样就势必产生一个问题:FSR能够直接连续寻址的范围是256字节(bank0/1或bank2/3),要覆盖最大 512字节的内部数据存储空间,又该如何定义指针?PICC还是将这一问题留给编程员自己解决:在定义指针时必须明确指定该指针所适用的寻址区域。 2021-6-5 Down Up Main Return 例如:unsigned char *ptr0; /定义覆盖 bank0/1的指针bank2 unsigned char *ptr1; /定义覆盖 bank2/3的指针bank3 unsigned char *ptr2; /定义覆盖 bank2/3的指针 2021-6-5 Down Up Main Return 上面定义了三个指针变量,其中指针没有任何bank限定,缺省就是指向 bank0和bank1;和一个指明了bank2,另一个指明了bank3,但实际上两者是一样的,因为一个指针可以同时覆盖两个bank的存储区域。 2021-6-5 Down Up Main Return 既然定义的指针有明确的bank适用区域,在对指针变量赋值时就必须实现类型匹配,下面的指针赋值将产生致命错误:unsigned char *ptr0; /定义指向bank0/1的指针bank2 unsigned char buff8; /定义bank2的一个缓冲区 2021-6-5 Down Up Main Return 程序语句:ptr0 = buff;/错误!试图将bank2内的变量地址赋给指向bank0/1的指针 若出现上述错误的指针操作,PICC 在最后链接时会告知类似于下面的信息: Fixup overflow in expression (.) 2021-6-5 Down Up Main Return 根据以往的编程经验,如果你看到了“ Fixup overflow”的错误指示,几乎可以肯定是指针类型不匹配的赋值所至。请重点检查程序中有关指针的操作。 2021-6-5 Down Up Main Return 指向 ROM 常数的指针 如果一组变量是已经被定义在ROM区的常数,那么指向它的指针可以这样定义: 2021-6-5 Down Up Main Return const unsigned char company =“Microchip”; /定义ROM中的常数 const unsigned char *romPtr; /定义指向ROM的指针 2021-6-5 Down Up Main Return 程序中可以对上面的指针变量赋值和实现取数操作:romPtr company; /指针赋初值 data = *romPtr+; /取指针指向的一个数, 然后指针加 1 2021-6-5 Down Up Main Return 反过来,下面的操作将是一个错误,因为该指针指向的是常数型变量,不能赋值。*romPtr data; /往指针指向的地址写一个数 2021-6-5 Down Up Main Return 指向函数的指针单片机编程时函数指针的应用相对较少,但作为标准C语法的一部分,PICC同样支持函数指针调用。如果你对编译原理有一定的了解,就应该明白在PIC单片机这一特定的架构上实现函数指针调用的效率是不高的: 2021-6-5 Down Up Main Return PICC将在RAM中建立一个调用返回表,真正的调用和返回过程是靠直接修改 PC 指针来实现的。因此,除非特殊算法的需要,建议大家尽量不要使用函数指针。 2021-6-5 Down Up Main Return 指针的类型修饰 前面介绍的指针定义都是最基本的形式。和普通变量一样,指针定义也可以在前面加上特殊类型的修饰关键词,例如“persistent”、“volatile”等。 2021-6-5 Down Up Main Return bank 修 饰 词 的 位 置 含 义 前面介绍的一些指针有的作用于 bank0/1,有的作用于bank2/3,但它们本身的存放位置全部在 bank0。 2021-6-5 Down Up Main Return 显然,在一个程序设计中指针变量将有可能被定位在任何可用的地址空间,这时,bank修饰词出现的位置就是一个关键,看下面的例子: unsigned char *ptr0; /定义指向bank0/1的指针, 指针变量位于bank0中 2021-6-5 Down Up Main Return bank2 unsigned char *ptr0; /定义指向bank2/3的指针, 指针变量位于 bank0 中bank2 unsigned char * bank1 ptr0; /定义指向bank2/3的指针, 指针变量位于bank1中 2021-6-5 Down Up Main Return 从中可以看出规律:前面的bank修饰词指明了此指针的作用域;后面的bank修饰词定义了此指针变量自身的存放位置。只要掌握了这一法则,你就可以定义任何作用域的指针且可以将指针变量放于任何bank中。 2021-6-5 Down Up Main Return volatile、 persistent和 const修 饰 词的 位 置 含 义 如果能理解上面介绍的bank修饰词的位置含义,实际上volatile、persistent 和const这些关键词出现在前后不同位置上的含义规律是和bank一词相一致的。例如: 2021-6-5 Down Up Main Return volatile unsigned char *ptr0; /定义指向bank0/1易变型字符变量的指针,指针变量位于bank0中且自身为非易变型 。 2021-6-5 Down Up Main Return bank2 unsigned char * volatile bank1 ptr0; /定义指向bank2/3非易变型字符变量的指针,指针变量位于bank1中且自身为易变型 2021-6-5 Down Up Main Return const unsigned char * const ptr0; /定义指向ROM区的指针,指针变量本身也是存放于ROM区的常数。 通过以上三个例子可以知道:出现在前面的修饰词其作用对象是指针所指向的变量;出现在后面的修饰词其作用对象就是指针变量自己。 2021-6-5 Down Up Main Return 中档系列PIC单片机的程序空间有分页的概念,但用C语言编程时基本不用太关心代码的分页问题。因为所有函数或子程序调用时的页面设定(如果代码超过一个页面)都由编译器自动生成的指令实现。 2021-6-5 Down Up Main Return PICC决定了C源程序中的一个函数经编译后生成的机器码一定会放在同一个程序页面内。中档系列的PIC单片机其一个程序页面的长度是2K字,换句话说,用C语言编写的任何一个函数最后生成的代码不能超过2K字。 2021-6-5 Down Up Main Return 一个良好的程序设计应该有一个清晰的组织结构,把不同的功能用不同的函数实现是最好的方法;因此一个函数2K字长的限制一般不会对程序代码的编写产生太多影响。 2021-6-5 Down Up Main Return 如果为实现特定的功能确实要连续编写很长的程序,这时就必须把这些连续的代码拆分成若干函数,以保证每个函数最后编译出的代码不超过一个页面空间(2K)。 2021-6-5 Down Up Main Return PICC在编译时将严格进行函数调用时的类型检查。一个良好的习惯是在编写程序代码前先声明所有用到的函数类型。例如:void Task(void); unsigned char Temperature(void); 2021-6-5 Down Up Main Return void BIN2BCD(unsigned char);void TimeDisplay(unsigned char, unsigned char); 这些类型声明确定了函数的入口参数和返回值类型,这样编译器在编译代码时就能保证生成正确的机器码。 2021-6-5 Down Up Main Return 在实际编程中有时碰到一些用户声称发现C编译器生成了错误的代码,最后究其原因就是因为没有事先声明函数类型所致。 2021-6-5 Down Up Main Return 建议大家在编写一个函数的源代码时,立即将此函数的类型声明复制到源文件的起始处,见本章的第一个例子;或是复制到专门的包含头文件中,再在每个源程序模块中引用。 2021-6-5 Down Up Main Return PICC可以实现C语言的中断服务程序。中断服务程序有一个特殊的定义方法: void interrupt ISR(void); 2021-6-5 Down Up Main Return 其中的函数名“ISR”可以改成任意合法的字母或数字组合;其入口参数和返回参数类型必须是“void”型,亦即没有入口参数和返回参数;中间必须有一个关键词“interrupt”。 2021-6-5 Down Up Main Return 中断函数可以被放置在源程序的任意位置,因为已有关键词“interrupt”声明。PICC在最后进行代码链接时会自动将其定位到0004H中断入口处,实现中断服务响应。编译器也会实现中断函数的返回指令“RETFIE”。 2021-6-5 Down Up Main Return 一个简单的中断服务示范函数如下: void interrupt ISR(void) /中断服务程序 if (T0IE /清除TMR0中断标志/在此加入TMR0 中断服务 2021-6-5 Down Up Main Return if (TMR1IE /清除 TMR1 中断标志 /在此加入TMR1中断服务 /中断结束并返回 2021-6-5 Down Up Main Return PICC会自动加入代码实现中断现场的保护,并在中断结束时自动恢复现场,所以编程员无需象编写汇编程序那样加入中断现场保护和恢复的额外指令语句。但如果在中断服务程序中需要修改某些全局变量时,是否需要保护这些变量的初值将由编程员自己决定和实施。 2021-6-5 Down Up Main Return 用C语言编写中断服务程序必须遵循高效的原则: 代码尽量简短,中断服务强调的是一个“快”字;中档系列PIC单片机的中断入口只有一个,因此整个程序中只能有一个中断服务函数。 2021-6-5 Down Up Main Return 避免在中断内使用函数调用。虽然PICC允许在中断里调用其它函数,但为了解决递归调用的问题,此函数必须为中断服务独家专用。既如此,不妨把原本要写在其它函数内的代码直接写在中断服务程序中。 2021-6-5 Down Up Main Return 避免在中断内进行数学运算。数学运算将很有可能用到库函数和许多中间变量,就算不出现递归调用的问题,光在中断入口和出口处为了保护和恢复这些中间临时变量就需要大量的开销,严重影响中断服务的效率。 2021-6-5 Down Up Main Return PICC提供了较完整的C标准库函数支持,其中包括数学运算函数和字符串操作函数。在程序中使用这些现成的库函数时需要注意的是入口参数必须在bank0中。 2021-6-5 Down Up Main Return 如果需要用到数学函数,则应在程序前“#include ”包含头文件;如果要使用字符串操作函数,就需要包含“#include ”头文件。在这些头文件中提供了函数类型的声明。通过直接查看这些头文件就可以知道 PICC 提供了哪些标准库函数。 2021-6-5 Down Up Main Return C语言中常用的格式化打印函数“printf/sprintf”用在单片机的程序中时要特别谨慎。printf/sprintf是一个非常大的函数,一旦使用,程序代码长度就会增加很多。 2021-6-5 Down Up Main Return PICC提供了相关的预处理指令以实现在源程序中定义单片机的配置字和标记单元。 2021-6-5 Down Up Main Return 在源程序中定义 PIC 单片机工作配置字的重要性在前面章节中已经阐述。在用 PICC写程序时同样可以在C源程序中定义,具体方式如下: _ _CONFIG (HS 2021-6-5 Down Up Main Return 上面的关键词“_ _CONFIG”(注意前面有两个下划线符)是专门用于芯片配置字的设定;后面括号中的各项配置位符号在特定型号单片机的头文件中已经定义(注意不是 pic.h头文件); 2021-6-5 Down Up Main Return 相互之间用逻辑“与”操作符组合在一起。这样定义的配置字信息最后将和程序代码一起放入同一个HEX文件。在这里列出了适用于16FXX系列单片机配置位符号预定义,其它型号或系列的单片机配置字定义方式类似,使用前查阅一下对应的头文件即可。 2021-6-5 Down Up Main Return /*振荡器配置*/ #define RC 0 x3FFF / RC 振荡#define HS 0 x3FFE / HS 模式高速晶体/陶瓷振荡器#define XT 0 x3FFD / XT 模式晶体/陶瓷振荡器#define LP 0 x3FFC / LP 模式低功耗振荡器 2021-6-5 Down Up Main Return /*看门狗配置*/ #define WDTEN 0 x3FFF /看门狗打开#define WDTDIS 0 x3FFB /看门狗关闭 2021-6-5 Down Up Main Return /*上电延时定时器配置*/#define PWRTEN 0 x3FF7 /上电延时定时器打开#define PWRTDIS 0 x3FFF /上电延时定时器关闭 2021-6-5 Down Up Main Return /*低电压复位配置*/ #define BOREN 0 x3FFF /低电压复位允许#define BORDIS 0 x3FBF /低电压复位禁止 2021-6-5 Down Up Main Return /*代码保护配置*/#define UNPROTECT 0 x3FFF /没有代码保护#define PROTECT 0 x3FEF /程序代码保护
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 压缩资料 > 基础医学


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!