keil编译不了,程序哪里错了吗,求大神帮忙看一下

[复制链接]
1824 0

本文包含原理图、PCB、源代码、封装库、中英文PDF等资源

您需要 登录 才可以下载或查看,没有帐号?注册会员

x
#include <AT89X51.H>
unsigned char code table[]={0x3f,0x06,0x5b,0x4f,0x66}//  0 1 2 3 4   


unsigned char time1;                              //////延时函数参数///////           
/////////////////////////////变量说明//////////////////////////////////////                              
unsigned char time2;
unsigned char time3;
unsigned char count;
unsigned char ms;
////////////////////////////////////////函数说明////////////////////////////////

void  initial(void);                                           ////初始化函数////
//void  initial_time0(void);                                      //////定时器0初始化///////


void  anjian(void);                                                                                                ////////////按键函数////
void  delay(unsigned char time1,time2,time3);                  ////延时函数////
void  disp(unsigned char count);                              /////静态显示子函数/////
void  delay1(char ms);

void  fangbo(void);                                                                                                //方波函数//
void  sanjiaobo(void);                                                                                        //三角波函数//
void  juchibo(void);                                                                                        //锯齿波函数//
void  tixingbo(void);                                                                                //正弦波函数//



void  main (void)
{
        initial();
        while(1)
        {
                anjian();
  }
}
/*************************************************************************
//函数名称:void anjian(void)
//函数说明:按键函数
//函数功能:
//    注意:
*************************************************************************/
void  anjian(void)
{

  if(P3_7==0)
   {delay(1,50,248);
    if(P3_7==0)
     {count=1;
      disp(count);
          fangbo();
     }
   }
   while(P3_7==0);
        count=0;
        disp(count);
        anjian();
}
/*************************************************************************
//函数名称:void fangbo(void)
//函数说明:方波函数
//函数功能:
//    注意:
*************************************************************************/
void  fangbo(void)
{
        while(1)
          {
                unsigned char fangbo_1;
                  fangbo_1+=8;
                  if(fangbo_1>128&fangbo_1<256)        {P0=0x00;}                                 
                  if(fangbo_1<128)                                {P0=0xff;}
       
                  if(P3_7==0)
                           {delay(1,50,248);
                    if(P3_7==0)
                             {        count=2;
                                         disp(count);
                                      sanjiaobo();
                               
                             }
                           }
            while(P3_7==0);
        }         
}
/*************************************************************************
//函数名称:void sanjiaobo(void)
//函数说明:三角波函数
//函数功能:
//    注意:
*************************************************************************/
void  sanjiaobo(void)
{
        while(1)
        {
                  unsigned char sanjiaobo_2;
                  if(sanjiaobo_2<=128)
                        {P0=sanjiaobo_2;}
                  else
                        {P0=255-sanjiaobo_2;}
                  sanjiaobo_2+=5;        
                  if(sanjiaobo_2>=255)
                        {sanjiaobo_2=0x00;}
                         
                         if(P3_7==0)
                           {
                                delay(1,50,248);
                            if(P3_7==0)
                             {count=3;
                                         disp(count);
                                      juchibo();
                                       
                                  }
                        }
            while(P3_7==0);
        }
}
/*************************************************************************
//函数名称:void juchibo(void)
//函数说明:锯齿波函数
//函数功能:
//    注意:
*************************************************************************/
void  juchibo(void)
{
        while(1)
        {
                  unsigned char juchibo_3;
                  if(juchibo_3<180)        {P0=juchibo_3;}   
                  juchibo_3+=4;        
                  if(juchibo_3>=180)        {juchibo_3=0x00;}
                        if(P3_7==0)
                   {
                        delay(1,50,248);
                    if(P3_7==0)
                             {count=4;
                                        disp(count);
                                      tixingbo();
                                }
                         }
        while(P3_7==0);
        }         
}
/*************************************************************************
//函数名称:void tixingbo(void)
//函数说明:梯形波函数
//函数功能:
//    注意:
*************************************************************************/
void tixingbo(void)
{
        while(1)
        {
            unsigned char tixingbo_4;
                  if(tixingbo_4<120)
                        {P0=tixingbo_4;}
                  else if(tixingbo_4==120)
                      delay1(1);
                   else if(tixingbo_4<240)
                          {P0=240-tixingbo_4;}
                         if(tixingbo_4==240)
                          {delay1(1);}
       
               
                  if(tixingbo_4>240)
                        {
                        tixingbo_4=0x00;
                       
                        }       
                       
                                  tixingbo_4+=10;
                        if(P3_7==0)
                           {delay(1,50,248);
                            if(P3_7==0)
                             {        count=0;
                                         disp(count);
                                      anjian();
                               
                                  }
                        }
           while(P3_7==0);
        }
}
/*************************************************************************
//函数名称:void initial(void)
//函数说明:初始化函数
//函数功能:
//    注意:
*************************************************************************/
void  initial(void)
      {
         P0=0xff;
         P1=0xff;
         P2=0xff;
         P3=0xff;
      }
/*************************************************************************
//函数名称:delay(unsigned char time1,time2,time3)
//函数说明:延时函数
//函数功能:
//入口参数:unsigned char time1,time2,time3
//出口参数:
//    注意:延时时间的计算:(time1*time2*time3*8us)us   
            time1,time2,time3可以不进行变量说明  
*************************************************************************/
void  delay(unsigned char time1,time2,time3)
       {
         unsigned char i,j,k;
          for(i=time1;i>0;i--)
             {  for(j=time2;j>0;j--)
                  {
                     for(k=time3;k>0;k--);
                  }
             }
        }
/*************************************************************************
//函数名称:disp(unsigned char count)
//函数说明:静态显示子函数
//函数功能:
//入口参数:unsigned char count
//出口参数:
//    注意:
*************************************************************************/
void  disp(unsigned char count)
      {  
         P2=table[count];
         delay(1,5,248);
      }

   void delay1(char ms)
{
char ti;
while(ms--)
{
  for(ti=0;ti<16;ti++){}
}
}

举报

回复
您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

图文热点

更多

社区学堂

  • Ameya360邀请您参加2017 ROHM科技展Ameya360邀请您参加2017 ROHM科技展 尊敬的客户: 您好!感谢您一直以来对罗姆的支持与厚爱! 罗姆将于2017年11月
  • 智能家居生态论(上)智能家居生态论(上) 从问题开始? 让我们从一个问题开始!学会提问是成长的开始, 受两“罗”的《长谈
  • 好书推荐好书推荐 LABVIEW宝典(第2版)简版电子书出炉了,需要赶紧下 此书你不得不读的几个理由:
更多

客服中心

QQ:187196467 服务时间:周一至周日 8:30-20:30

关注我们

快速回复 返回列表 客服中心 搜索 官方QQ群
关于我们
关于我们
友情链接
联系我们
帮助中心
网友中心
购买须知
支付方式
服务支持
资源下载
售后服务
定制流程
关注我们
官方微博
官方空间
官方微信
快速回复 返回顶部 返回列表