这是全部程序,
    求哪里出错了,报警器不作用
    
#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);
}