这是全部程序,
求哪里出错了,报警器不作用
#include<reg51.H>
#include<absacc.H>
#include <intrins.h>
#include<stdio.h>
#define uchar unsigned char
#define uint unsigned int
sbit K1=P3^5;
sbit K2=P3^6;
sbit K3=P3^7;
sbit K4=P3^4;
sbit BJ=P3^0;
uchar num=50;
extern int SX;
extern int XX;
int sx,xx;
uchar code TAB[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xc6}; //数字
uchar code TAB1[]={0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10};
//小数
sbit DQ=P3^3; //1温度输入口
sbit DE=P3^2;//2温度输入口
void delay(uint i)
//延时
{
while(i--);
}
void DelayMS(uint ms)
//DS延迟12秒
{
uchar i;
while(ms--)
for(i=0;i<120;i++);
}
void display(int k)//数码管显示,DS18B20一输出温度值,p0输出段码。
{
P2=0x08;
//数码管倒着00001000,p2位码
P0=0xc6;//个位
DelayMS(5);
P2=0x04;
P0=TAB[k/10%10]; //十位
DelayMS(7);
P2=0x02;
P0=TAB1[k/100%10];//百位,采用小数码
DelayMS(7);
P2=0x01;
P0=TAB[k/1000]; //千位
DelayMS(7);
}
void play(int k)//数码管显示,DS18B20二温度输出,P1输出段码。
{
P2=0x80;
P1=0xc6; //个
DelayMS(5);
P2=0x40;
P1=TAB[k/10%10]; //十
DelayMS(7);
P2=0x20;
P1=TAB1[k/100%10];
//百
DelayMS(7);
P2=0x10;
P1=TAB[k/1000]; //千
DelayMS(7);
}
void init_DS() //B20一复位
{
uchar x=0;
DQ=1;
delay(8);
DQ=0;
delay(85);
DQ=1;
delay(14);
x=DQ;
delay(20);
}
void init_DX() //B20二复位
{
uchar x=0;
DE=1;
delay(8);
DE=0;
delay(85);
DE=1;
delay(14);
x=DE;
delay(20);
}
Read(void) //18B20一写字节
{
uchar i=0;
uchar dat=0;
for(i=8;i>0;i--)
{
DQ=1;
delay(1);
DQ=0;
dat>>=1;
DQ=1;
if(DQ)
dat|=0x80;
delay(4);
}
return(dat);
}
rd(void)
//18B20二写字节
{
uchar j=0;
uchar date=0;
for(j=8;j>0;j--)
{
DE=1;
delay(1);
DE=0;
date>>=1;
DE=1;
if(DE)
date|=0x80;
delay(4);
}
return(date);
}
write(uchar dat)// 18B20一读字节
{
uchar i=0;
for(i=8;i>0;i--)
{
DQ=0;
DQ=dat&0x01;
delay(5);
DQ=1;
dat>>=1;
}
delay(4);
}
wr(uchar date) //18B20二读字节
{
uchar j=0;
for(j=8;j>0;j--)
{
DE=0;
DE=date&0x01;
delay(5);
DE=1;
date>>=1;
}
delay(4);
}
Readtem(void)//读出温度函数一
{
uchar a=0;
uchar b=0;
uchar t=0,t1;
t=0;
init_DS();
write(0xcc);//skip ROM
write(0x44); //发转换命令
delay(125);
init_DS();
//总线复位
write(0xcc); //发skip ROM命令
write(0xbe); //发读命令
a=Read();//温度低八位
b=Read();//温度高八位
t1=(a&0x0f)*0.0625;
t=((b<<4)|(a>>4));
if(t>128)
{
t=~t+1;
}
t=t+t1;
return(t);
}
rtem(void)//读出温度函数二
{
uchar c=0;
uchar d=0;
uchar T=0,T1;
T=0;
init_DX();
wr(0xcc);
wr(0x44);
delay(125);
init_DX();
wr(0xcc);
wr(0xbe);
c=rd();//低八位
d=rd();//高八位
T1=(c&0x0f)*0.0625;
T=((d<<4)|(c>>4));
if(T>128)
{
T=~T+1;
}
T=T+T1;
return(T);
}
void shangxian(int m)//上限输出,在B20一中输出
{
P2=0x08;
P0=TAB[m%10]; //个
DelayMS(5);
P2=0x04;
P0=TAB1[m/10%10]; //十
DelayMS(7);
P2=0x02;
P0=TAB[m/100%10];
//百
DelayMS(7);
P2=0x01;
P0=TAB1[5];//千,规定为"S."
DelayMS(7);
}
void xiaxian(int n)//下限输出,B20一输出
{
P2=0x08;
P0=TAB[n%10];
DelayMS(5);
P2=0x04;
P0=TAB1[n/10%10];
DelayMS(7);
P2=0x02;
P0=TAB[n/100%10];
DelayMS(7);
P2=0x01;
P0=TAB1[5];//千,规定为"S."
DelayMS(7);
}
void Keyscan()//按键设置
{
if(K1==0)//K1加
{
DelayMS(2);//延时去抖
if(K1==0)
{
while(!K1);//等待按键释放
num++;//如果数值键被按下数值增加
if(num==120)//num==120时,复原num=50
num=50;
}
}
if(K2==0)//K2减
{
DelayMS(2);
if(K2==0)
{
while(!K2);
num--;
if(num==20)
num=50;
}
}
if(K3==1)//转换上限显示
{
DelayMS(2);
if(K3==1)
{
while(!K3);
num++;
if(num%2==0)
num=0;
}
if(K4==1)//转换下限显示
{
DelayMS(2);
if(K4==1)
{
while(!K4);
num++;
if(num%2==0)
num=0;
}
}
}
}
void ber(int s,int x) //
{
sx=SX*10;
xx=XX*10;
BJ=!s>sx;
BJ=!x>sx;
BJ=!s<xx;
BJ=!x<xx;
}
void main()
{
float tp;
float TP;
int BJ=1;
while(1)
{
if(K3==1)
{
tp=Readtem();
TP=rtem();
tp=tp*100;
TP=TP*100;
display(tp);
play(TP);
}
else if(K4==0)
{
XX=200;
Keyscan();
XX=XX+(num-50)*10;
xiaxian(XX);
}
else
{
SX=300;
Keyscan();
SX=SX+(num-50)*10;
shangxian(SX);
}
}
ber(tp,TP);
}