欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

標題: 單片機eeprom如何存大于256的數 [打印本頁]

作者: shenshaohai    時間: 2020-2-19 15:30
標題: 單片機eeprom如何存大于256的數
想做一個帶eeprom的0-999的計數器不知道大于256的數怎么處理 只會做0-99的計數器 求大佬們幫忙
作者: wulin    時間: 2020-2-19 17:17
unsigned int a,b;
unsigned char c,d;
a=999;//最大65535
//分解為2個字節保存在eeprom
c=a;//溢出部分拋棄
d=a>>8;
//讀取eeprom后合并為1個16位數據
b=d<<8|c;
作者: xuyaqi    時間: 2020-2-19 17:21
把大于256的數分解成高8位與低8位2個8位來存,如果用C語言直接用int類型存,編譯器給你搞定。
作者: shenshaohai    時間: 2020-2-19 19:26
wulin 發表于 2020-2-19 17:17
unsigned int a,b;
unsigned char c,d;
a=999;//最大65535

#include <REGX52.H>
#define uchar unsigned char
#define uint unsigned int
bit write=0;
sbit sda=P2^0;
sbit scl=P2^1;
sbit dula=P2^6;
sbit wela=P2^7;
uint sec;
uint tect;
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71};
void delay()
{ ; ; }
void delay1(uint mun)
{
        uint x,y;
         for(x=mun;x>0;x--)
                for(y=110;y>0;y--);

}
void init()
{
        sda=1;
        delay();
        scl=1;
        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<255)
                i++;
        scl=0;
        delay();
}
void write_byte(uint date)
{
        uchar i;
        uint k;
        k=date;
         for(i=0;i<8;i++)
         {
                        k=k<<1;
                 scl=0;
                delay();
       
                sda=CY;
                delay();
                scl=1;
                delay();
         }
         scl=0;
         delay();
         sda=1;
         delay();
}
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;
                delay();
                scl=0;
                delay();
        }
        //scl=1;
        //delay();
        //sda=1;
        //delay();
        return k;
}
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();
        //delay1(5);
        start();
        write_byte(0xa1);
        respons();
        date=read_byte();
        //respons();
        stop();
        return date;
}
void display(uint bai,uint shi,uint ge)
{
        dula=0;
        P0=table[bai];
        dula=1;
        dula=0;
        wela=0;
        P0=0x7e;
        wela=1;
        wela=0;
        delay1(5);
       
        dula=0;
        P0=table[shi];
        dula=1;
        dula=0;
        wela=0;
        P0=0x7d;
        wela=1;
        wela=0;
        delay1(5);
       
        dula=0;
        P0=table[ge];
        dula=1;
        dula=0;
        wela=0;
        P0=0x7b;
        wela=1;
        wela=0;
        delay1(5);
}
void main()
{
        init();
        sec=read_add(2)+256*read_add(3);
        if(sec>1000)
                sec=0;
        TMOD=0x01;
        TH0=(65536-50000)/256;
        TL0=(65536-50000)%256;
        EA=1;
        ET0=1;
        TR0=1;
        while(1)
        {
                display(sec/100,sec%100/10,sec%10);
                if(write==1)
                {
                        write=0;
                       
                        write_add(2,sec);
                        //delay1(100);
                        write_add(3,sec>>8);
                }
        }
}
void t0() interrupt 1
{
        TH0=(65536-50000)/256;
        TL0=(65536-50000)%256;
       
        tect++;
        if(tect==1)
        {
                tect=0;
                sec++;
                write=1;
                if(sec==1000)
                        sec=0;
        }
}
你看看我這樣子寫哪里有問題?
作者: shenshaohai    時間: 2020-2-19 19:27
xuyaqi 發表于 2020-2-19 17:21
把大于256的數分解成高8位與低8位2個8位來存,如果用C語言直接用int類型存,編譯器給你搞定。

#include <REGX52.H>
#define uchar unsigned char
#define uint unsigned int
bit write=0;
sbit sda=P2^0;
sbit scl=P2^1;
sbit dula=P2^6;
sbit wela=P2^7;
uint sec;
uint tect;
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71};
void delay()
{ ; ; }
void delay1(uint mun)
{
        uint x,y;
         for(x=mun;x>0;x--)
                for(y=110;y>0;y--);

}
void init()
{
        sda=1;
        delay();
        scl=1;
        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<255)
                i++;
        scl=0;
        delay();
}
void write_byte(uint date)
{
        uchar i;
        uint k;
        k=date;
         for(i=0;i<8;i++)
         {
                        k=k<<1;
                 scl=0;
                delay();
       
                sda=CY;
                delay();
                scl=1;
                delay();
         }
         scl=0;
         delay();
         sda=1;
         delay();
}
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;
                delay();
                scl=0;
                delay();
        }
        //scl=1;
        //delay();
        //sda=1;
        //delay();
        return k;
}
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();
        //delay1(5);
        start();
        write_byte(0xa1);
        respons();
        date=read_byte();
        //respons();
        stop();
        return date;
}
void display(uint bai,uint shi,uint ge)
{
        dula=0;
        P0=table[bai];
        dula=1;
        dula=0;
        wela=0;
        P0=0x7e;
        wela=1;
        wela=0;
        delay1(5);
       
        dula=0;
        P0=table[shi];
        dula=1;
        dula=0;
        wela=0;
        P0=0x7d;
        wela=1;
        wela=0;
        delay1(5);
       
        dula=0;
        P0=table[ge];
        dula=1;
        dula=0;
        wela=0;
        P0=0x7b;
        wela=1;
        wela=0;
        delay1(5);
}
void main()
{
        init();
        sec=read_add(2)+256*read_add(3);
        if(sec>1000)
                sec=0;
        TMOD=0x01;
        TH0=(65536-50000)/256;
        TL0=(65536-50000)%256;
        EA=1;
        ET0=1;
        TR0=1;
        while(1)
        {
                display(sec/100,sec%100/10,sec%10);
                if(write==1)
                {
                        write=0;
                       
                        write_add(2,sec);
                        //delay1(100);
                        write_add(3,sec>>8);
                }
        }
}
void t0() interrupt 1
{
        TH0=(65536-50000)/256;
        TL0=(65536-50000)%256;
       
        tect++;
        if(tect==1)
        {
                tect=0;
                sec++;
                write=1;
                if(sec==1000)
                        sec=0;
        }
}
我這樣子寫 哪里出現問題了
作者: myd51    時間: 2020-2-19 19:45
強制類型轉換符可以幫你做到。取高8位,低8位。
作者: npn    時間: 2020-7-25 20:19
能用union的地方就不要用移位,影響效率

  1. #include "reg51.h"
  2. void main(){
  3.         union {
  4.                 unsigned char c[4];
  5.                 unsigned long l;        //最大4294967295
  6.         } b;
  7.         b.l = 0xABCD1234;
  8.         P0 = b.c[0];
  9.         P1 = b.c[1];
  10.         P2 = b.c[2];
  11.         P3 = b.c[3];
  12.         while (1);
  13. }
復制代碼

作者: lxbhcy    時間: 2020-7-28 11:41
拆成2個8位,或者3個,4個,看你數據大小要求
作者: 12345678110    時間: 2020-7-28 11:50
拆分啊  就像 時分秒  最大不就59   但是告訴你 20:58:50  你能算成秒吧  告訴你  3650秒 你能換算成時吧




歡迎光臨 (http://www.raoushi.com/bbs/) Powered by Discuz! X3.1