分享

keil中code 关键字的作用

 云澳 2016-07-31
keil中code 关键字的作用 - 卷土虫来 - 卷土虫来
本文为个人总结,如有错误,欢迎指正
一般说来,我们在C语言中定义的每一个变量初始化后都会占用一定的内存(RAM)空间。但是在keil中提供了提

一个特殊的关键字“code”,这个关键字在标准C中是没有的。其语法举例如下:
unsigned char code word[] = {
      0x04,0x10,0x34,0x08,0xC4,0x06,0x04,0x01,
      0xC4,0x82,0x3C,0x8C,0x20,0x40,0x10,0x30,
      0x0F,0x0C,0xE8,0x03,0x08,0x0C,0x08,0x10,
      0x28,0x60,0x18,0xC0,0x00,0x40,0x00,0x00,
};
int code vel = 1201;
我们知道,在单片机中一般都有两块存储区域,ROM和RAM,程序代码存储在ROM中,程序要用的变量存储在RAM中

。而“code”的作用就是将其修饰过的变量存储在ROM中而非RAM。
在单片机中,RAM空间都比较小,是比较宝贵的。“code”的意义就是将一些初始化后值一直保持不变的变量(如

:固定的常数、表格、常量数组、只读常量等)放置于ROM区,从而节省了RAM空间。
注意:用“code”修饰的变量是不能在程序运行时改变的!

补充内容
转自:Grant的工作笔记 http://blog.csdn.net/gasbi/article/details/6186312
KEIL MDK 查看代码量、RAM使用情况--RO-data、RW-data、ZI-data的解释
KEIL RVMDK编译后的信息

Program Size: Code=86496 RO-data=9064 RW-data=1452 ZI-data=16116 

Code是代码占用的空间,RO-data是 Read Only 只读常量的大小,如const型,RW-data是(Read Write) 初始化了的可读写变量的大小,ZI-data是(Zero Initialize) 没有初始化的可读写变量的大小。ZI-data不会被算做代码里因为不会被初始化。
简单的说就是在烧写的时候是FLASH中的被占用的空间为:Code+RO Data+RW Data
程序运行的时候,芯片内部RAM使用的空间为: RW Data + ZI Data

摘自:百度知道 http://zhidao.baidu.com/question/127457049.html

Q:在AVR GCC中如何使用C语言在程序空间申请常量数组?就像在KEIL中使用CODE或者PCODE的功能
A:GCC中把大数组存入flash区的方法大全
AVRGCC中将变量定义在flash空间的方法(大数据存储)

(1)flash常量:

        #include  <avr\pgmspace.h>//须增加的头文件

        const prog_uchar FlashConst = 3;        //定义uchar型的常量n定义在flash里(flash常量)

        unsigned char RamVar;                         //定义无符号整型变量(Ram变量)

        RamVar = pgm_read_byte(&FlashConst); //读取flash常量到ram变量

(2)flash一维数据:

        #include  <avr\pgmspace.h>

        const prog_uchar  s[5] =  { 1, 2, 3, 4, 5 };

        unsigned char RamVar;                         //定义无符号整型变量(Ram变量)

        RamVar = pgm_read_byte( &s[1] );    //读取s[1]的值到RamVar, or  RamVar = pgm_read_byte( s+1 );   

(3)flash多维数据:

        #include  <avr\pgmspace.h>

        const prog_uchar  s[4][16] =  { {14, 4,13, 1, 2,15,11, 8, 3,10, 6,12, 5, 9, 0, 7 },
                                                     { 0,15, 7, 4,14, 2,13, 1,10, 6,12,11, 9, 5, 3, 8 },
                                                     { 4, 1,14, 8,13, 6, 2,11,15,12, 9, 7, 3,10, 5, 0 },
                                                     {15,12, 8, 2, 4, 9, 1, 7, 5,11, 3,14,10, 0, 6,13 }
                                                  };

        unsigned char RamVar[4],[16];                         //定义无符号整型变量(Ram变量)

        register char i, j;

        for(i=0; i<4; ++)

        {

                for(j=0; j<16; j++)

                {

                        RamVar[i][j]  = pgm_read_byte( &s[i][j] );    //读取数组s的值到RamVar

                }//end for 2

        }//end for 1

(4)扩展部分

avr对ram和flash是独立编址的,ram是按8位编址,而flash却按16位编址,读ram和读flash的汇编指令也是不同的。
类似flash数据类型还有:prog_void 、prog_char 、prog_int8_t、prog_uint8_t、prog_int16_t、prog_uint16_t、prog_int32_t、prog_uint32_t等。
读取指令pgm_read_xxx宏定义其实就是一段包括了flash读取指令的内联汇编代码。函数原型为:pgm_read_byte(address_short)、pgm_read_word(address_short)、 pgm_read_dword(address_short)、pgm_read_float(address_short)。括号中是地址值。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多