PIC單片機CCS之C語言(#IF,#ENDIF的用法)
#ELSE
本文引用地址:http://www.ex-cimer.com/article/201611/315395.htm#ELIF
#ENDIF
語法: #if expr
code
#elif expr
code
#else
code
#endif
expr是一個常數(shù)表達式,標準算子或預處理器標識符;
Code是任意的標準C源程序.
目的: 預處理器求出常數(shù)表達式的值,如果這個值是非0值,就處理可選項#ELSE或#ENDIF的上面的所有行.
注意:你不可在#IF里使用C變量,只有預處理器通過#define創(chuàng)造的才可使用.
若id被定義了,則預處理器表達式DEFINED(id)可用來返回1,若沒有定義id,則DEFINED(id)返回的值為0.
例子:#if MAX_VALUE>255
long value; //若MAX_VALUE>255,則將value定義為長整型變量
#else
int value; //若MAX_VALUE不大于255, 則將value定義為整型變量
#endif
例子文件:ex_extee.c
文件: ex_extee.c如下:
#if defined(__PCB__) //若使用了PCB編譯器,則defined( __PCB__)返回值為1
#include <16c56.h> //包含16c56.h頭文件
#fuses HS, NOWDT, NOPROTECT //HS:高速晶振/諧振器, NOWDT:不使用WDT
// NOPROTECT:程序存儲器代碼不保護
#use delay(clock=20000000) //使能內(nèi)置函數(shù)的功能:delay_ms()和delay_us()
//#USE DELAY()必須在#use rs232()使用之前出現(xiàn).
#use rs232(baud=9600, xmit=PIN_A3, rcv=PIN_A2)
//使用波特率為9600,
//發(fā)送腳為PIN_A3
//接收腳為PIN_A2
//使能內(nèi)置函數(shù):GETC,PUTC和PRINTF, kbhit();
#elif defined(__PCM__)
#include <16F877.h>
#fuses HS,NOWDT,NOPROTECT,NOLVP
#use delay(clock=20000000)
#use rs232(baud=9600, xmit=PIN_C6, rcv=PIN_C7) // Jumpers: 8 to 11, 7 to 12
#elif defined(__PCH__)
#include <18F452.h>
#fuses HS,NOWDT,NOPROTECT,NOLVP
#use delay(clock=20000000)
#use rs232(baud=9600, xmit=PIN_C6, rcv=PIN_C7) // Jumpers: 8 to 11, 7 to 12
#endif //結束if定義
#include
#include <2416.c> //包含2416.c頭文件
void main() {
BYTE value, cmd; //聲明字節(jié)型變量value, cmd
EEPROM_ADDRESS address; //用EEPROM_ADDRESS代替long int,為16位
init_ext_eeprom(); //初始化連接到eeprom的I/O腳
do {
do {
printf("rnRead or Write: ");
cmd=getc(); //從RS232口讀一個字節(jié)
cmd=toupper(cmd); //將cmd中的小寫字母轉換成大寫字母送給cmd
putc(cmd);
} while ( (cmd!=R) && (cmd!=W) ); //直到輸入R或W為止
printf("nrLocation: ");
#if sizeof(EEPROM_ADDRESS)==1
//若定義EEPROM_ADDRESS是1個字節(jié),則sizeof(EEPROM_ADDRESS)==1返回1
address = gethex();
#else //若定義EEPROM_ADDRESS是大于1個字節(jié)
#if EEPROM_SIZE>0xfff
address = gethex();
#else // EEPROM_SIZE小于0xfff
address = gethex1(); //從RS232口讀一個字節(jié),為eeprom存儲高字節(jié)地址
#endif //結束if定義
address = (address<<8)+gethex(); //從RS232口讀2個字節(jié),為eeprom存儲低字節(jié)地址
#endif //結束if定義
if(cmd==R) //若輸入R,則執(zhí)行下面
printf("rnValue: %Xrn",READ_EXT_EEPROM( address ) );
if(cmd==W) {
printf("rnNew value: ");
value = gethex(); //從RS232輸入,為寫入eeprom的值做準備
printf("nr");
WRITE_EXT_EEPROM( address, value );
}
} while (TRUE);
}
文件: input.c如下:
#include
BYTE gethex1() {
char digit; //聲明字節(jié)型變量digit
digit = getc(); //從RS232口讀一個字節(jié)
putc(digit); //向RS232口寫一個字節(jié)
if(digit<=9) //將讀到的字節(jié)以16進制返回
return(digit-0); //若讀到的ascii碼小于或等于39,則將其減30,以16進制返回
else
return((toupper(digit)-A)+10); //若讀到的ascii碼大于39,則將其減41,再加10返回
}
BYTE gethex() {
int lo, hi; //聲明整型變量lo, hi
hi = gethex1(); //從RS232口讀一個字節(jié),存儲到hi中
lo = gethex1(); //從RS232口讀一個字節(jié),存儲到lo中
if(lo==0xdd)
return(hi);
else
return( hi*16+lo );
}
void get_string(char* s, int max) {
int len; //聲明整型變量len
char c; //聲明字節(jié)型變量c
--max; //初始化max值
len=0; //初始化len值
do {
c=getc(); //從RS232口讀一個字節(jié),存儲到c中
if(c==8) { // Backspace若是空格鍵
if(len>0) {
len--;
putc(c); //向RS232寫c
putc( );
putc(c);
}
} else if ((c>= )&&(c<=~))
if(len s[len++]=c; putc(c); } } while(c!=13); s[len]=0; } // stdlib.h is required for the ato_ conversions // in the following functions #ifdef _STDLIB //若定義_STDLIB,則執(zhí)行下面 signed int get_int() { char s[5]; //聲明字符型數(shù)組s[5] signed int i; //聲明有符號整型變量i get_string(s, 5); //從RS232口讀5個字節(jié),存儲到s數(shù)組中 i=atoi(s); //將數(shù)組s[]的字符串轉換成整型數(shù)送給i return(i); } signed long get_long() { char s[7]; //聲明字符型數(shù)組s[7] signed long l; //聲明有符號長整型變量l get_string(s, 7); //從RS232口讀7個字節(jié),存儲到s數(shù)組中 l=atol(s); //將數(shù)組s[]的字符串轉換成長整型數(shù)送給l return(l); } float get_float() { char s[20]; //聲明字符型數(shù)組s[7] float f; //聲明符點型變量l get_string(s, 20); //從RS232口讀20個字節(jié),存儲到s數(shù)組中 f = atof(s); //將數(shù)組s[]的字符串轉換成符點數(shù)送給f return(f); } #endif //結束if定義 文件: 2416.c如下: //// Library for a MicroChip 24LC16B //// //// init_ext_eeprom(); Call before the other functions are used //// //// write_ext_eeprom(a, d); Write the byte d to the address a //// //// d = read_ext_eeprom(a); Read the byte d from the address a //// //// b = ext_eeprom_ready(); Returns TRUE if the eeprom is ready //// //// to receive opcodes //// //// The main program may define EEPROM_SDA //// //// and EEPROM_SCL to override the defaults below. //// //// Pin Layout //// //// ----------------------------------------------------------- //// //// | | //// //// | 1: NC Not Connected | 8: VCC +5V | //// //// | 2: NC Not Connected | 7: WP GND | //// //// | 3: NC Not Connected | 6: SCL EEPROM_SCL and Pull-Up | //// //// | 4: VSS GND | 5: SDA EEPROM_SDA and Pull-Up | //// //// ----------------------------------------------------------- //// #ifndef EEPROM_SDA //若沒有定義EEPROM_SDA,則執(zhí)行下面 #define EEPROM_SDA PIN_C4 //用EEPROM_SDA代替PIN_C4 #define EEPROM_SCL PIN_C3 //用EEPROM_SCL代替PIN_C3 #endif //結束if定義 #use i2c(master, sda=EEPROM_SDA, scl=EEPROM_SCL) // master設置成主機方式 //除非指定了FORCE_HW,否則會產(chǎn)生模擬I2C的軟件函數(shù). //使能I2C_START, I2C_STOP直到下一個#USE I2C的出現(xiàn)為止. //使能I2C_READ, I2C_WRITE直到下一個#USE I2C的出現(xiàn)為止. //使能I2C_POLL直到下一個#USE I2C的出現(xiàn)為止. //指定sda腳為EEPROM_SDA, 指定scl腳為EEPROM_SCL #define EEPROM_ADDRESS long int //用EEPROM_ADDRESS代替long int #define EEPROM_SIZE 2048 //用EEPROM_SIZE代替2048 void init_ext_eeprom() { output_float(EEPROM_SCL); //將EEPROM_SCL引腳設為輸入,開集電極連接 output_float(EEPROM_SDA); //將EEPROM_SDA引腳設為輸入,開集電極連接 } BOOLEAN ext_eeprom_ready() { int1 ack; //聲明位變量ack i2c_start(); //發(fā)送啟動條件 ack = i2c_write(0xa0); //發(fā)送從機地址0xa0;若ack=0,表示從機應答(ACK); //若ack=1,表示從機不應答(NO ACK); i2c_stop(); //發(fā)送停止條件 return !ack; } // ext_eeprom_ready()函數(shù),若返回1,表示從機準備好; 若返回0,表示從機忙或eeprom壞了 void write_ext_eeprom(long int address, BYTE data) { while(!ext_eeprom_ready()); //若從機忙,則主機等待 i2c_start(); //發(fā)送啟動條件 i2c_write( (0xa0|(BYTE)(address>>7))&0xfe); //發(fā)送命令字的高字節(jié)(發(fā)送寫命令) i2c_write(address); //發(fā)送命令字的低字節(jié) i2c_write(data); //發(fā)送數(shù)據(jù) i2c_stop(); //發(fā)送停止條件 } BYTE read_ext_eeprom(long int address) { BYTE data; //聲明字節(jié)變量data while(!ext_eeprom_ready()); //先發(fā)器件地址,若從機忙,則主機等待 i2c_start(); //在此處是:發(fā)送重新啟動條件 i2c_write( (0xa0|(BYTE)(address>>7))&0xfe); //發(fā)送命令字的高字節(jié)(發(fā)送寫命令) i2c_write(address); //發(fā)送命令字的低字節(jié) i2c_start(); //發(fā)送啟動條件 i2c_write( (0xa0|(BYTE)(address>>7))|1); //發(fā)送命令字的高字節(jié)(發(fā)送讀命令) data=i2c_read(0); //讀I2C數(shù)據(jù),然后發(fā)送ack=0(不用從機應答) i2c_stop(); //發(fā)送停止條件 return(data); //返回所讀到的I2C數(shù)據(jù) } 上面的例子主要用來讀寫24C16,通過PC機RS232進行驗證
評論