keil軟件使用總結


1 編譯選項

編譯選項有:

Translate:Translate the current active file.  翻譯當前改動的文件,用來檢查語法錯誤,不生成目標文件。

Build:Build target files. 編譯目標文件,只對更改的源文件進行一個編譯,同時生成連接可執行文件。如果是第一次編譯,會對所有的文件進行一個編譯。

Rebuild:Rebuild all target files. 對多有的文件進行一個編譯。

Batch Build:Perform a batch build. 進行批量編譯。

2 添加.c與.h文件

2.1 創建文件夾

工程文件夾中新建一個文件User,然后在User文件中新建Src(存放.c文件)和Inc(存放.h文件)兩個文件夾。

2.2 創建源文件

new兩個空白文件,一個保存在Src文件夾中,為.c文件;另一個保存在Inc文件夾中,為.h文件。

2.3 添加分組

在工程中添加一個分組,並對分組進行命名。

2.4 在分組中添加文件

將新建的.c文件添加至分組中。

2.5 添加.h文件路徑

3 #ifndef #define #endif

創建一個頭文件后,要在.h文件中添加如下幾條語句:

#ifndef __XXX_H #define __XXX_H




#endif

上面的XXX是指該頭文件的名字,一般用大寫字母表示。例如delay.h,XXX就是DELAY。

其實這就是一個判斷語句:

判斷條件為是否定義了__XXX_H;

執行范圍在#ifndef __XXX_H至#endif中間(如果滿足if條件,就執行這個范圍里的語句);

#endif就是一個if判斷結束標志。

加這幾條判斷語句的目的:

可以避免重復編譯,例如:

a.h中包含了delay.h;

b.h中也包含了delay.h;

最后main.h中包含a.h與b.h;

那么在編譯的過程中,只有a.h中的delay.h會被編譯,后面b.h中delay不會被編譯。

4 注釋顯示亂碼的解決方法

 

5 在keil中添加STC芯片包的方法

使用STC-ISP軟件,如下圖所示。

 

 

 

/*---------------------------------------------------------------------*//* --- STC MCU Limited ------------------------------------------------*//* --- STC15F4K60S4 系列 AD轉換查詢方式舉例----------------------------*//* --- Mobile: (86)13922805190 ----------------------------------------*//* --- Fax: 86-0513-55012956,55012947,55012969 ------------------------*//* --- Tel: 86-0513-55012928,55012929,55012966-------------------------*//* --- Web: www.STCMCU.com --------------------------------------------*//* --- Web: www.GXWMCU.com --------------------------------------------*//* 如果要在程序中使用此代碼,請在程序中注明使用了STC的資料及程序        *//* 如果要在文章中應用此代碼,請在文章中注明使用了STC的資料及程序        *//*---------------------------------------------------------------------*/
//本示例在Keil開發環境下請選擇Intel的8058芯片型號進行編譯//若無特別說明,工作頻率一般為11.0592MHz

#include "reg51.h"#include "intrins.h"
#define FOSC    11059200L#define BAUD    115200
typedef unsigned char BYTE;typedef unsigned int WORD;
#define     URMD    0           //0:使用定時器2作為波特率發生器                                //1:使用定時器1的模式0(16位自動重載模式)作為波特率發生器                                //2:使用定時器1的模式2(8位自動重載模式)作為波特率發生器
sfr T2H   = 0xd6;               //定時器2高8位sfr T2L   = 0xd7;               //定時器2低8位
sfr P1M1 = 0x91;    //PxM1.n,PxM0.n     =00--->Standard,    01--->push-pullsfr P1M0 = 0x92;    //                  =10--->pure input,  11--->open drainsfr P0M1 = 0x93;sfr P0M0 = 0x94;sfr P2M1 = 0x95;sfr P2M0 = 0x96;sfr P3M1 = 0xB1;sfr P3M0 = 0xB2;sfr P4M1 = 0xB3;sfr P4M0 = 0xB4;sfr P5M1 = 0xC9;sfr P5M0 = 0xCA;sfr P6M1 = 0xCB;sfr P6M0 = 0xCC;sfr P7M1 = 0xE1;sfr P7M0 = 0xE2;
sfr  AUXR       =   0x8e;       //輔助寄存器                              
sfr ADC_CONTR   =   0xBC;           //ADC控制寄存器sfr ADC_RES     =   0xBD;           //ADC高8位結果sfr ADC_LOW2    =   0xBE;           //ADC低2位結果sfr P1ASF       =   0x9D;           //P1口第2功能控制寄存器
#define ADC_POWER   0x80            //ADC電源控制位#define ADC_FLAG    0x10            //ADC完成標志#define ADC_START   0x08            //ADC起始控制位#define ADC_SPEEDLL 0x00            //540個時鍾#define ADC_SPEEDL  0x20            //360個時鍾#define ADC_SPEEDH  0x40            //180個時鍾#define ADC_SPEEDHH 0x60            //90個時鍾
void InitUart();void InitADC();void SendData(BYTE dat);BYTE GetADCResult(BYTE ch);void Delay(WORD n);void ShowResult(BYTE ch);
void main(){    P0M0 = 0x00;    P0M1 = 0x00;    P1M0 = 0x00;    P1M1 = 0x00;    P2M0 = 0x00;    P2M1 = 0x00;    P3M0 = 0x00;    P3M1 = 0x00;    P4M0 = 0x00;    P4M1 = 0x00;    P5M0 = 0x00;    P5M1 = 0x00;    P6M0 = 0x00;    P6M1 = 0x00;    P7M0 = 0x00;    P7M1 = 0x00;
    InitUart();                     //初始化串口    InitADC();                      //初始化ADC    while (1)    {        ShowResult(0);              //顯示通道0        ShowResult(1);              //顯示通道1        ShowResult(2);              //顯示通道2        ShowResult(3);              //顯示通道3        ShowResult(4);              //顯示通道4        ShowResult(5);              //顯示通道5        ShowResult(6);              //顯示通道6        ShowResult(7);              //顯示通道7    }}
/*----------------------------發送ADC結果到PC----------------------------*/void ShowResult(BYTE ch){    SendData(ch);                   //顯示通道號    SendData(GetADCResult(ch));     //顯示ADC高8位結果
//    SendData(ADC_LOW2);           //顯示低2位結果}
/*----------------------------讀取ADC結果----------------------------*/BYTE GetADCResult(BYTE ch){    ADC_CONTR = ADC_POWER | ADC_SPEEDLL | ch | ADC_START;    _nop_();                        //等待4個NOP    _nop_();    _nop_();    _nop_();    while (!(ADC_CONTR & ADC_FLAG));//等待ADC轉換完成    ADC_CONTR &= ~ADC_FLAG;         //Close ADC
    return ADC_RES;                 //返回ADC結果}
/*----------------------------初始化串口----------------------------*/void InitUart(){    SCON = 0x5a;                //設置串口為8位可變波特率#if URMD == 0    T2L = (65536 - (FOSC/4/BAUD));    T2H = (65536 - (FOSC/4/BAUD)) >> 8;    AUXR = 0x14;                //T2為1T模式, 並啟動定時器2    AUXR |= 0x01;               //選擇定時器2為串口1的波特率發生器#elif URMD == 1    AUXR = 0x40;                //定時器1為1T模式    TMOD = 0x00;                //定時器1為模式0(16位自動重載)    TL1 = (65536 - (FOSC/4/BAUD));    TH1 = (65536 - (FOSC/4/BAUD)) >> 8;    TR1 = 1;                    //定時器1開始啟動#else    TMOD = 0x20;                //設置定時器1為8位自動重裝載模式    AUXR = 0x40;                //定時器1為1T模式    TH1 = TL1 = (256 - (FOSC/32/BAUD));    TR1 = 1;#endif}
/*----------------------------初始化ADC----------------------------*/void InitADC(){    P1ASF = 0xff;                   //設置P1口為AD口    ADC_RES = 0;                    //清除結果寄存器    ADC_CONTR = ADC_POWER | ADC_SPEEDLL;    Delay(2);                       //ADC上電並延時}
/*----------------------------發送串口數據----------------------------*/void SendData(BYTE dat){    while (!TI);                    //等待前一個數據發送完成    TI = 0;                         //清除發送標志    SBUF = dat;                     //發送當前數據}
/*----------------------------軟件延時----------------------------*/void Delay(WORD n){    WORD x;
    while (n--)    {        x = 5000;        while (x--);    }}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM