51单片机的24c02怎么搞啊,有没人帮我看看五六行的程序,谢谢了啊

2024-12-20 22:23:33
推荐回答(2个)
回答1:

把这个程序看懂相信你的问题可以解决 希望对你有帮助

//at24c02测试实验
//24c02是存储芯片,可以将数据永久的存放在芯片中,保证掉电不丢失数据。
//本实验在数码管上显示0~F的数据,并将这个数据存放在at24c02中,上电后保存上次的数据,并显示。
#include
#define uchar unsigned char
#define duan P0
#define wei P1
uchar code dis[]=
{0xc0,0xf9,0xa4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0xA0,0x83,0xC6,0xA1,0x84,0x8E};
sbit sda=P2^0; //数据线
sbit scl=P2^1; //时钟线
uchar a;
//短暂延时
void delay()
{ ;; }
//开始信号
void start()
{
sda=1;
delay();
scl=1;
delay();
sda=0;
delay();
}
//停止信号
void stop()
{
sda=0;
delay();
scl=1;
delay();
sda=1;
delay();
}
//应答信号
void respons()
{
uchar i;
scl=1;
delay();
while((sda==1)&&(i<250))i++;
scl=0;
delay();
}
//初始化
void init()
{
sda=1;
delay();
scl=1;
delay();
}
//向24c02写一个字节数据
void write_byte(uchar date)
{
uchar i,temp;
temp=date;
for(i=0;i<8;i++)
{
temp=temp<<1;
scl=0;
delay();
sda=CY;
delay();
scl=1;
delay();
//scl=0;
// delay();
}
scl=0;
delay();
sda=1;
delay();
}
//从24c02读一个字节数据
uchar read_byte()
{
uchar i,k;
scl=0;
delay();
sda=1;
delay();
for(i=0;i<8;i++)
{
scl=1;
delay();
k=(k<<1)|sda;
scl=0;
delay();
}
return k;
}
void delay1(unsigned int x)
{
unsigned int a,b;
for(a=x;a>0;a--)
for(b=100;b>0;b--);
}
//向指定地址写数据
void write_add(uchar address,uchar date)
{
start();
write_byte(0xa0);
respons();
write_byte(address);
respons();
write_byte(date);
respons();
stop();
}
//从指定地址读数据
uchar read_add(uchar address)
{
uchar date;
start();
write_byte(0xa0);
respons();
write_byte(address);
respons();
start();
write_byte(0xa1);
respons();
date=read_byte();
stop();
return date;
}
//主函数
void main()
{
uchar count = 0;
init();//初始化
wei = 0xfe;
while(1)
{
count=read_add(23);//先从at24c02中读数据
duan = dis[count]; //显示读出的数据
count =(count+1)%16; //将数据控制在0~f
write_add(23,count); //写入新数据
delay1(1000);
}
}

回答2:

如果你确定你的时序操作没有问题的话 就在你写24c02和读24c02之间加个延时 不要写完马上就读 给单片机点反应时间 还有就是好好检查一下时序对没有