单片机,用AT24C02扩展,代码有问题。 存四个数到指定的AT24c02连续的4个单元地址中,再从此地址中连续读出4个数据显示到数码管上。

#include
#include
#define uchar unsigned char
#define Addwr 0xa0;
#define AddRd 0xa1;
sbit SDA=P1^7;
sbit SCL=P1^6;
sbit WP=P1^5;
void Delay(int len)
{
int i,j;
for(i=0;i<len;i++)
for(j=0;j<100;j++);
}
void Start(void) //起始
{
SDA=1;
SCL=1;
_Nop();_Nop();_Nop();_Nop();_Nop();//延时5us
SDA=0;
_Nop();_Nop();_Nop();_Nop();_Nop();//延时5us
SCL=0;
}
void Stop(void)//终止
{
SDA=0;
SCL=1;
_Nop();_Nop();_Nop();_Nop();_Nop();//延时5us
SDA=1;
_Nop();_Nop();_Nop();_Nop();_Nop();//延时5us
SDA=0;
}
void Ack(void) //应答位函数
{
uchar i;
SDA=1;
SCL=1;
_Nop();_Nop();_Nop();_Nop();//延时4us
SCL=0;
_Nop();_Nop();_Nop();_Nop();//延时4us
}
void NoAck(void)//非应答位函数
{
SDA=1;
SCL=1;
_Nop();_Nop();_Nop();_Nop();//延时4us
SCL=0;
SDA=0;
}
void send(uchar Data)
{
uchar BitCounter=8;
uchar ack;
uchar temp;
do
{
temp=Data;
SCL=0;
_Nop();_Nop();_Nop();_Nop();
if((temp&0x80)==0x80)//最高位是1
SDA=1;//发送的数据的左移1位
else SDA=0;
SCL=1;
temp=Data<<1;
Data=temp;
BitCounter--;
}
while(BitCounter);
SCL=0;
_Nop();_Nop();_Nop();_Nop();
SDA=1;
_Nop();_Nop();_Nop();_Nop();
SCL=1;
_Nop();_Nop();_Nop();_Nop();
if(SDA==1)
ack=0;
else ack=1;
SCL=1;
_Nop();_Nop();
}
Read(void)//读一个字节的函数
{
uchar temp=0;
uchar temp1=0;
uchar BitCounter=8;
SDA=1;
do
{
SCL=0;
_Nop();_Nop();_Nop();_Nop();
SCL=1;
_Nop();_Nop();_Nop();_Nop();
if(SDA)
temp=temp|0x01;
else temp=temp&0xfe;
if(BitCounter=1)
{
temp=temp<<1;
temp=temp1;
}
BitCounter--;
}
while(BitCounter);
return(temp);
}
void WriteROM(uchar Data[],uchar Address,uchar Num)
{
uchar i;
uchar ack;
uchar *PData;
PData=Data;
for(i=0;i<Num;i++)
{
Start();
send(0xa0);
if(ack==0)

send(Address+i);
if(ack==0)

send(*(PData+i));
if(ack==0)

Stop();
Delay(20);

}
}
void main(void)
{
uchar Number[4]={9,9,7,5};
TMOD=0x11;
TH0=0xee;
TL0=0x00;
TR0=1;
ET0=1;
EA=1;
WP=1;
WriteROM(Number[4],4); //将数组中的数据写入存储器
Delay(20);
Numder[0]=0;
Numder[1]=0;
Numder[2]=0;
Numder[3]=0;//将数组清0
ReadROM(Number[4],4); //写入存储器的数据读回到数组
while(1);
}
void WriteROM(uchar Data[],uchar Address,uchar Num)
{
uchar i;
uchar PData;
PData=Data;
for(i=0;i<Num;i++)
{
Start();
send(0xa0);
if(ack==0)
return(0);
send(Address+i);
if(ack==0)
return(0);
send(
(PData+i));
if(ack==0)
return(0);
Stop();
Delay(20);
}
}
void ReadROM(uchar Data[],uchar Address,uchar Num)
{
uchar i;
uchar *PData;
PData=Data;
for(i=0;i {
Start();
send(0xa0);
if(ack==0)
return(0);
send(Address+i);
if(ack==0)
return(0);
Star();
send(0xa1);
if(ack==0)
return(0);
*(PData+i)=Read();
SCL=0;
NoAck();
Stop();
}
}
void timer0() interrupt 1
{
static unsigned char Bit=0;
TH0=THCO;
TL0=TLCO;
Bit++;
if(Bit>=4)
Bit=0;
P2|=0xf0;
P0=Duan[Data[Bit]];
switch(Bit)
{
case 0: P24=0;
break;
case 1: P25=0;
break;
case 2: P26=0;
break;
case 3: P27=0;
break;
}
}

1个回答

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
单片机中AT24C02问题,初学者,希望大家帮帮我

#include "reg52.h"#include "intrins.h"sbit SDA=P2^1;//总线连接口定义sbit SCL=P2^0;//总线连接口定义sbit duan=P2^2;sbit wei=P2^3;typedef unsigned char uchar;uchar duanma[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};uchar weima[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};uchar t[8];void delay(uchar m)//us延时作用{ while(--m);}void delays(uchar t)//ms延时作用{ while(t--) { delay(245); delay(245); }}/*void display(uchar firstbit,uchar weishu){ static unsigned char i; P0=0; duan=1; duan=0; P0=weima[firstbit+i]; wei=1; wei=0; P0=t[i]; duan=1; duan=0; i++; if(i==weishu) i=0;}*//*void time_0()interrupt 1{ TH0=(65536-2000)/256; TL0=(65536-2000)%256; display(0,8);}*/void iic_start()//开始通知芯片读写开始。{ SDA=1;//上来先让数据线置高电平 SCL=1;//接着让时钟线置高电平 delay(5);//SDA和SCL同时为高电平保持4.7us以上 _nop_();//1.805us,共5.78us,下面SDA=0;是下降沿,不能计算在延时时间中 SDA=0;//在时钟线为高电平,而数据线由高电平到低电平的过程读写芯片开始进行.//下降沿 delay(5);//SDA低电平保持4us以上,这里是4.34us满足要求。 //注意开始后SCL为1,SDA为0; }void iic_inti()//总线初始化{ SCL=1;//=-----————————————————————>>>>>>>>>>>>>让时钟线和数据线都为高电平 SDA=1;//------——————————————————>>>>>>>>>>>>让时钟线和数据线都为高电平 delay(5);}void iic_stop(){ SDA=0; _nop_();//准备状态 SCL=1; //————————————————————————>>>>>>>>结束信号是时钟线为高电平,而数据线由低电平到高电平的过程 delay(5);//该稳态需要保持时间为4us以上。 SDA=1;//SCL高电平期间,SDA来一个上升沿, delay(5);//SDA保持4US以上,4.34加上函数返回时间大于4.7us; //注意结束时SCL和SDA都为1;}void iic_sendbyte(uchar bytedate)//发送一个字节{ uchar i,temp; temp=bytedate; for(i=0;i<8;i++) { temp=temp<<1;//移动后最高位到了PSW寄存器的CY位中。 SCL=0;//准备发送阶段 _nop_();//稳定一下 SDA=CY;//将发送的数据一位位的发送到CY位的SDA上 _nop_();//稳定一下 SCL=1;//每一个高电平期间,IC器件都会将数据取走 _nop_();//稳定一下 } SCL=0;//如果写成SCL=1,SDA=1;就是停止信号了,所以不能那样写 _nop_(); SDA=1;//释放总线,数据总线不用时要释放 _nop_();}uchar iic_readbyte(){ uchar i,temp; SCL=0;//准备读数据 _nop_(); SDA=1;//释放总线 _nop_(); for(i=0;i<8;i++) { SCL=1;//MCU开始取数据 delay(5);//SCL为高电平后,IC器件就会将一位数据送到SDA上, //总共用时不会大于4.34us的,然后就可以让MCU度SDA了 temp=(temp<<1)|SDA;//读一位,保存到temp中。 SCL=0; delay(5); } return temp;}bit iic_checkACK()//处理信号{ uchar errcount=255;//定义超时量为255次 SCL=1; _nop_(); while(SDA) { //在一段时间内检测到SDA=0的话认为是应答信号 if(0==errcount) { SCL=0;//钳住总线 _nop_(); return 0;//没有应答信号 } errcount--; } SCL=0;//钳住总线,为下一次通信做准备 _nop_(); return 1;//成功处理应答信号}void iic_sendACK(bit b_ACK)//发送应答或非应答信号{ SCL=0;//准备 _nop_(); if(b_ACK)//ACK { SDA=0; } else //UACK { SDA=1; } _nop_(); SCL=1; delay(5);//大于4us的延时 SCL=0;// 钳住SCL,以便接受数据. _nop_();}void AT24c02_writebyte(unsigned char addr,unsigned char byte)//向24c02写一个字节数据{ iic_start(); iic_sendbyte(0xa0);//MCU写控制字,前四位固定1010,后三位地址0,末位0是写数据的模式 iic_checkACK();//MCU 处理应答信号 iic_sendbyte(addr);// 准备在指定的地址写入 iic_checkACK(); iic_sendbyte(byte);//写数据 iic_checkACK(); iic_stop(); delays(2);//按字节写入时,24c02在接收到停止信号后,将数据擦写到内部,这需要时间 //并且在这段时间内不会响应总线上的任何请求,固让MCU有2毫秒以上的等待 } void AT24c02_writeData(unsigned char address,unsigned char numbytes,unsigned char *buf)//写入任意长度数据 { while(numbytes--) { AT24c02_writebyte(address++,*buf++); }} void AT24c02_readData(unsigned char beignAddr,unsigned char dataSize,unsigned char *buf)//读取任意长度字节 { iic_start();//起始信号 iic_sendbyte(0xa0);//控制字,写的模式//控制字,读的模式//1010(固定模式)000,地址;最后一位是控制读或写的模式,1为读,0为写 iic_checkACK();//处理应答信号 iic_sendbyte(beignAddr);//发送地址 iic_checkACK();//处理应答信号 iic_start();//发送起始信号 iic_sendbyte(0xa1);//控制字,读的模式//1010(固定模式)000,地址;最后一位是控制读或写的模式,1为读,0为写 iic_checkACK();//处理应答信号 while(dataSize--) { *buf++=iic_readbyte();//读取一个个字节并保存到缓冲区buf中, iic_sendACK(dataSize);//发送应答,当dataSize为0时发送非应答 } iic_stop();//发送停止信号}unsigned char dat[]={0x7f,0xbf,0xdf,0xef, 0xf7,0xfb,0xfd,0xfe, 0xff,0xff,0x00,0x00, 0x55,0x55,0xaa,0xaa };//ram允许情况可以无限添加i;void main(){ uchar i; iic_inti(); AT24c02_writeData(0xae,16,dat); //写入24c02 //第一个数据0xae,代表大地址,第二个1,代表小弟指,一个24c02的小地址的范围是0--250, //第三个是代表数据的地址 delays(1); for(i=0;i<16;i++) dat[i]=0; AT24c02_readData(0xae,16,dat); //从24c02读数据 //第一个数据0xae,代表大地址,第二个1,代表小弟指,一个24c02的小地址的范围是0--250, //第三个是代表数据的地址 while(1) { for(i=0;i<16;i++) //查表 { delays(200); P1=dat[i]; } }} 这个程序为什么只有插上数据线和时钟线才能出现跑马灯效果,不插为什么led灯不亮呢。

关于51单片机的1602液晶结合AT24C02显示时钟程序的相关问题

我在郭天祥的单片机书上看到关于1602液晶显示时钟的程序,然后我把对照这个模板写, 发现程序出现一个警告, 板子无法正常在1602上显示。 求各位大佬讲解。 //main.c// #include<reg52.h> #include"IIC.H" #include<intrins.h> #define uchar unsigned char uchar count,keynum; char sec,min,hour; sbit lcden=P1^2; //液晶使能端 sbit lcdrs=P2^0; sbit buzz=P0^6; sbit key1=P3^0; sbit key2=P3^1; sbit key3=P3^2; uchar code table[]="2017-06-07"; void Delay5ms() //@11.0592MHz { unsigned char i, j; i = 54; j = 199; do { while (--j); } while (--i); } void di() { P2=0XA0; buzz=1; Delay5ms(); P2=0x00; } void write_com(unsigned char date) { lcdrs=0; lcden=1; P0=date; Delay5ms(); lcden=0; } void write_data(unsigned char date) { lcdrs=1; lcden=1; P0=date; Delay5ms(); lcden=0; } void write_sfm(uchar add, uchar date) { uchar shi,ge; shi=date/10; ge=date%10; write_com(0x80+0x40+add); write_data(0x30+ge); write_data(0x30+shi); } void init1() { uchar num; sec=0; min=0; hour=0; keynum=0; count=0; init_24c02(); write_com(0x38); //模式 write_com(0x0c); //开显示,显示光标,不闪烁 write_com(0x06); //指针加1 write_com(0x01); //清屏 for(num=0;num<12;num++) { write_data(table[num]); } sec=read_add(1); min=read_add(2); hour=read_add(3); TMOD=0X01; TH0=(65536-50000)/256; TL0=(65536-50000)%256; EA=1; ET0=1; TR0=1; write_com(0x80+0x40+6); write_data(':'); Delay5ms(); write_com(0x80+0x40+9); write_data(':'); Delay5ms(); } void key_scan() { if(key1) { TR0=0; Delay5ms(); if(key1) { while(!key1); di(); keynum++; if(keynum==1) { write_com(0x80+0x40+10); write_data(0x0f); } if(keynum==2) { write_com(0x80+0x40+7); } if(keynum==3) { write_com(0x80+0x40+4); } if(keynum==4) { keynum=0; write_com(0x0c); TR0=1; } } if(!keynum) { if(key2) { Delay5ms(); if(key2) { while(!key3); di(); if(keynum==1) { sec++; if(sec==60) { sec=0; } write_sfm(10,sec); write_com(0x80+0x40+10); write_add(1,sec); } if(keynum==2) { min++; if(min==60) { min=0; } write_sfm(7,min); write_com(0x80+0x40+7); write_add(2,min); } if(keynum==3) { hour++; if(hour==60) { hour=0; } write_sfm(4,hour); write_com(0x80+0x40+4); write_add(3,hour); } } } if(key3) { Delay5ms(); if(key3) { while(!key3); di(); if(keynum==1) { sec--; if(sec==-1) { sec=60; } write_sfm(10,sec); write_com(0x80+0x40+10); write_add(1,sec); } if(keynum==2) { min--; if(min==0) { min=60; } write_sfm(7,min); write_com(0x80+0x40+7); write_add(2,min); } if(keynum==3) { hour--; if(hour==0) { hour=60; } write_sfm(4,hour); write_com(0x80+0x40+4); write_add(3,hour); } } } } } } void main() { init1(); while(1) { key_scan(); } } void timer0() interrupt 1 { TH0=(65536-50000)/256; TL0=(65536-50000)%256; count++; if(count==20) { count=0; sec++; if(sec==60) { sec=0; min++; if(min==60) { min=0; hour++; if(hour==60) { hour=0; } write_sfm(4,hour); write_add(3,hour); } write_sfm(7,min); write_add(2,min); } write_sfm(10,sec); write_add(1,sec); } } //IIC.c// #include <reg52.h> #include "IIC.H" #include<intrins.h> void delay0() { ;;} void Delay5us() { unsigned char i; _nop_(); _nop_(); i = 12; while (--i); } //开始信号 void start() { SDA=1; Delay5us(); SCL=1; Delay5us(); SDA=0; Delay5us(); SCL=0; Delay5us(); } //停止信号 void stop() { SDA=0; Delay5us(); SCL=1; Delay5us(); SDA=1; Delay5us(); } //主机应答反映 void send_renspons(bit date) { SDA=date; SCL=1; Delay5us(); SCL=0; Delay5us(); } //从机应答信号 bit re_renspons() { bit temp; SDA=1; Delay5us(); SCL=1; Delay5us(); if(SDA==1) temp=0; else temp=1; SCL=0; Delay5us(); return temp; } void init_24c02() { SDA=1; delay0(); SCL=1; delay0(); } //写数据_字节 void write_date(unsigned char date) { unsigned char i; for (i=0;i<8;i++) { if ((date<<i)&0x80) SDA=1; else SDA=0; SCL=1; Delay5us(); SCL=0; Delay5us(); } re_renspons(); } //读数据——字节 unsigned char read_date() { unsigned char i,temp; SDA=1; Delay5us(); for (i=0;i<8;i++) { temp<<=1; SCL=1; Delay5us(); if(SDA==1) temp=temp+1; SCL=0; Delay5us(); } return temp; } //写一个字节 void write_add(unsigned char addr,unsigned char date) { start(); write_date(0xa0); write_date(addr); write_date(date); stop(); } //读一个字节 unsigned char read_add(unsigned char addr) { unsigned char temp; start(); write_date(0xa0); write_date(addr); start(); write_date(0xa1); temp=read_date(); send_renspons(1); stop(); return temp; } //IIC.H// #ifndef _IIC_H_ #define _IIC_H_ sbit SCL=P2^0; sbit SDA=P2^1; void write_add(unsigned char addr,unsigned char date); unsigned char read_add(unsigned char addr); void init_24c02(); #endif ![图片说明](https://img-ask.csdn.net/upload/201706/08/1496855360_216038.png)

关于AT24C02的疑问 求大神

我想用该芯片实现掉电存储功能 比如设置一个温度上限 超过报警器会报警 但我有个疑问 若初始就给一个上限值 未经设置情况下会一直是这个值 若是设置之后才会写入24c02 来掉电存储 那该怎么来实现呢 有点绕不过去 简单说就是在第一次开机的时候 怎么能确保读出的是预先给的值而不是就去读24C02里还没写入的不确定的值 最好有代码

stm32开发版可以正常使用at24c02,

我把02芯片换成24c32以后,在头文件中把类型换成了对应的32,但是上电以后确实不能读写的,可能是什么原因

at24c02上电复位的问题

上电复位时一直复位不了,用示波器放到SDA管脚上就可以,是什么原因,是电源的事吗,但是这个供电范围是很宽的啊

AT24C02为什么需要复位两次才能正确显示存储信息

譬如第一次开机就能读取并显示正确的信息 下次开机必然会显示无关的一个数字 再开机一次 又是正确信息 如此循环

IIC 同时挂接AT24C08和MPU6050读写问题?

STM32 模拟IIC 。当总线上只有AT24C08且往AT24C08读写数据,没问题! 当总线上只有MPU6050且读MPU6050设备地址 OK! 当2个设备同时挂在IIC时,有趣的事来了,AT24C08读数据和MPU6050读设备地址没问题 ,往AT24C08写数据写不进去??拔掉6050的SCL线,AT24C08能正常读写,6050的SDA线拔插都不影响。。。

at24c02可以一次性读写256字节吗?那样的话就没页一说了吧

往里面写2字节时要不要考虑这2个字节在2个页里面,如果是在2个页,后面一个字节能写进后面一个页里面吗

AT24Cxx 读写问题 写出现不明白的问题

我用的是AT24C512来存储数据,但写地址的时候,写完16位的地址,然后再写一个8位数据; 在读出来的时候,读到的是高8位地址所指向的地址的数据,且数据等于地址的低8位,怎么也读不到16位地址所指向地址的数据。 //向指定地址写一个字节数据 Write_IIC(0x00,0x00,0x10); //向0x0000地址写数据0x10 Delay(5); Write_IIC(0x01,0x01,0x11); //向0x0101地址写数据0x11 Delay(5); Write_IIC(0x02,0x02,0x12); //向0x0202地址写数据0x12 Delay(5); Write_IIC(0x03,0x03,0x13); //向0x0303地址写数据0x13 Delay(5); Write_IIC(0x04,0x04,0x14); //向0x0404地址写数据0x14 Delay(5); //读指定地址的数据 Send_Data(Read_ICC(0x00,0x00)); //读0x0000地址的数据 Delay(1); Send_Data(Read_ICC(0x01,0x01)); //读0x0101地址的数据 Delay(1); Send_Data(Read_ICC(0x02,0x02)); //读0x0202地址的数据 Delay(1); Send_Data(Read_ICC(0x03,0x03)); //读0x0303地址的数据 Delay(1); Send_Data(Read_ICC(0x04,0x04)); //读0x0404地址的数据 Delay(1); 我是从串口接收数据,读出来的数据为: 01 02 03 04 14 证明只有最后一次写,才把0x14写到0x0404里面;或者最后一次是往地址0x04写了一次0x04,然后再写0x14,0x14把0x04覆盖了。 第一次往0x0000写0x10不成功,第二次把地址的低8位0x01写到高8位地址0x01里去了,第三次,第四次与第二次一样。 为什么会这样 uchar Read_ICC(uchar ADD_H,uchar ADD_L) { uchar dat; I2C_Start(); Send_Byte(0xa0); //发器件地址,并通知准备发送地址 Response(); //应答 Send_Byte(ADD_H); //发器件内部存储器地址高位 Response(); //应答 Send_Byte(ADD_L); //发器件内部存储器地址低位 Response(); //应答 I2C_Start(); Send_Byte(0xa1); //发器件地址,并通知准备读取数据 Response(); //应答 dat=Rcv_Byte(); //读取数据 I2C_Stop(); //停止I2C总线 return (dat); } void Write_ICC(uchar ADD_H,uchar ADD_L,uchar dat) { I2C_Start(); Send_Byte(0xa0); //发器件地址,并通知准备发送地址,要对应芯片地址 Response(); //应答 Send_Byte(ADD_H); //发器件内部存储器地址高位 Response(); //应答 Send_Byte(ADD_L); //发器件内部存储器地址低位 Response(); //应答 Send_Byte(dat); //写入数据 Response(); //应答 I2C_Stop(); //停止I2C总线 }

at24c32可以同时挂接几个,8个吗

at24c32数据地址是16位的,他就不占用器件地址的A0,A1,A2了,那么A0,A1,A2组合起来是不是可以挂接8个呢

关于at24c04的驱动程序

是用51单片机c语言编写的。可以在ptotou上面进行仿真。输入一个字节马上把他读出来

at24cxx在使用之前要对所有字节初始化为0啊

但是这样的初始化也就这一次吧,及时下次在断电上电也不再次初始化,这样该怎么写

at24c里面的东西掉电数据不丢失主要是写保护起作用吗

我只是网65533地址写入一个u16的数据,掉电重启数据怎么没了呢

51单片机通过IIC向EEPROM存储和读取数据

我用51单片机通过IIC向EEPROM存储数据,然后再把数据读出来,再通过串口发送出去, 再用串口调试工具(eaglecom)查看数据。。。最后发现一次只能发送或者读取12个 字节,大于12个字节之后的数据全是0xff。不知道原因是什么。 ```#include <reg52.h> #include "delay.h" #include "Uart.h" #define ERROR 0 #define SUCCESS 1 #define MAX 50 sbit SDA = P1^7; sbit SCK = P1^6; unsigned char ack = 0; void IIC_Start() { SDA = 1; SCK = 1; delay_us(1); SDA = 0; delay_us(1); SCK = 0; } void IIC_Stop() { SDA = 0; SCK = 1; delay_us(1); SDA = 1; delay_us(1); SCK = 0; } void IIC_ACK() { SDA = 0; SCK = 1; delay_us(1); SCK = 0; } void IIC_NOACK() { SDA = 1; SCK = 1; delay_us(1); SCK = 0; } void IIC_SendByte(unsigned char temp) { unsigned char i; for(i = 0; i < 8; i++) { SDA = temp & 0x80; SCK = 1; delay_us(1); SCK = 0; delay_us(1); temp <<= 1; } SCK = 1; SDA = 1; delay_us(1); if(0 == SDA) { ack = 1; } else { ack = 0; } SCK = 0; } unsigned char IIC_RecvByte() { unsigned char i, temp; SDA = 1; for(i = 0; i < 8; i++) { SCK = 0; delay_us(1); SCK = 1; temp <<= 1; if(1 == SDA) { temp = temp + 1; } } SCK = 0; return temp; } unsigned char AT24C02_SendStr(unsigned char deceviceaddr, unsigned char romaaddr, unsigned char *s, unsigned char num) { unsigned char i; IIC_Start(); IIC_SendByte(deceviceaddr); if(0 == ack) { return ERROR; } IIC_SendByte(romaaddr); if(0 == ack) { return ERROR; } for(i = 0; i < num; i++) { IIC_SendByte(*s); if(0 == ack) { return ERROR; } s++; } IIC_Stop(); return SUCCESS; } unsigned char AT24C02_RecvStr(unsigned char deceviceaddr, unsigned char romaaddr, unsigned char *s, unsigned char num) { unsigned char i; IIC_Start(); IIC_SendByte(deceviceaddr); if(0 == ack) { return ERROR; } IIC_SendByte(romaaddr); if(0 == ack) { return ERROR; } IIC_Start(); IIC_SendByte(deceviceaddr + 1); if(0 == ack) { return ERROR; } for(i = 0; i < num - 1; i++) { *s = IIC_RecvByte(); IIC_ACK(); s++; } *s = IIC_RecvByte(); IIC_NOACK(); IIC_Stop(); return SUCCESS; } void main() { unsigned char i = 0; unsigned char temp[MAX + 1]; unsigned char str[2]; Uart_init(); for(i = 0; i < MAX; i++) { temp[i] = 7; } if(!AT24C02_SendStr(0xae, 100, temp, MAX)) { return; } delay_ms(200); for(i = MAX; i < (MAX + 1) ;i++) { temp[i] = 0; } delay_ms(200); if(!AT24C02_RecvStr(0xae, 100, temp, MAX)) { return; } delay_ms(200); Uart_SendStr(temp); while(1); } ``` 如果用IICSendByte()和RecvByte(),一个字节一个字节发送和读取的话是不会出错的,但是封装成IICSendStr()和RecvByte()的话,发送或者是接收的字符串长度不能超过12。这是为什么?

FPGA以I2C读取at24c128,接收不到应答信号

程序如下,程序一直停留在状态“1010”,也就是接收不到ACK,求各位大神帮忙 -------------------div 50M change to 1M----------- process(clk1,reset) variable Count:integer range 0 to 51; begin if reset = '0' then--异步清零信号 Count:=0; elsif(clk1='1' and clk1'event) then if Count=25 then i2cclk<='0'; Count:=Count+1; elsif Count=50 then Count:=0; i2cclk<= '1'; else Count := Count+1; end if; end if; end process; ------------------------------------------------------- -------------------I2C write--------------------------- process(i2cclk,reset) variable i_cnt :integer range 8 downto 0:=8 ; variable ack_cnt :integer range 0 to 8:=0 ; variable ack_time :integer range 0 to 100:=0 ; variable d_cnt :integer range 0 to 80:=0 ; variable machine_addr:std_logic_vector(7 downto 0):="10100000"; variable i2caddrh:std_logic_vector(7 downto 0):="00000000"; variable i2caddrl:std_logic_vector(7 downto 0):="10100000"; variable i2cdata:std_logic_vector(7 downto 0):="01010101"; variable i2cwr_one :std_logic:='0';-- variable i2cdata_temp :std_logic:='0';-- begin if reset = '0' then i2cstatewr<="0000"; machine_addr:="10100000"; i2cdata:="01010101"; i2caddrh:="00000000"; i2cdata:="01010101"; i_cnt:=8; d_cnt:=0; i2cwr_one:='0'; ack_cnt:=0; led<='1'; elsif(i2cclk='1' and i2cclk'event) then case i2cstatewr is when "0000"=>--init d_cnt:=d_cnt+1; if d_cnt=1 then i2cda<='1'; i2cclk_s<='1'; i2cstatewr<="0000"; elsif d_cnt=delay_cnt then d_cnt:=0; -- if i2cwr_one='0' then i2cstatewr<="0001"; -- else -- i2cstatewr<="0000"; -- end if; else i2cstatewr<="0000"; end if; when "0001"=>--i2c start d_cnt:=d_cnt+1; if d_cnt=1 then i2cda<='0'; i2cstatewr<="0001"; elsif d_cnt=delay_cnt then d_cnt:=0; i2cstatewr<="0011"; else i2cstatewr<="0001"; end if; -- when "0010"=> -- i2cclk_s<='0'; -- i2cstatewr<="0011"; when "0011"=>--i2c send machineaddr ,addrh,addrl,data d_cnt:=d_cnt+1; if d_cnt=1 then i2cclk_s<='0'; i2cstatewr<="0011"; elsif d_cnt=delay_cnt then d_cnt:=0; i_cnt:=i_cnt-1; i2cstatewr<="0100"; else i2cstatewr<="0011"; end if; when "0100"=> d_cnt:=d_cnt+1; if d_cnt=1 then if ack_cnt=0 then i2cda<=machine_addr(i_cnt); elsif ack_cnt=1 then i2cda<=i2caddrh(i_cnt); elsif ack_cnt=2 then i2cda<=i2caddrl(i_cnt); elsif ack_cnt=3 then i2cda<=i2cdata(i_cnt); end if; i2cstatewr<="0100"; elsif d_cnt=delay_cnt then d_cnt:=0; i2cstatewr<="0101"; else i2cstatewr<="0100"; end if; when "0101"=> d_cnt:=d_cnt+1; if d_cnt=1 then i2cclk_s<='1'; i2cstatewr<="0101"; elsif d_cnt=delay_cnt then d_cnt:=0; if i_cnt=0 then i_cnt:=8; i2cstatewr<="0110"; else i2cstatewr<="0011"; end if; else i2cstatewr<="0101"; end if; when "0110" => --ninth clock d_cnt:=d_cnt+1; if d_cnt=1 then i2cclk_s<='0'; i2cstatewr<="0110"; elsif d_cnt=delay_cnt then --delay_cnt then d_cnt:=0; i2cstatewr<="0111"; else i2cstatewr<="0110"; end if; when "0111"=> d_cnt:=d_cnt+1; if d_cnt=1 then i2cda<='1'; i2cstatewr<="0111"; elsif d_cnt=delay_cnt then d_cnt:=0; i2cstatewr<="1000"; else i2cstatewr<="0111"; end if; when "1000"=>--wait ack d_cnt:=d_cnt+1; if d_cnt=1 then i2cclk_s<='1'; i2cstatewr<="1000"; elsif d_cnt=delay_cnt then d_cnt:=0; i2cstatewr<="1001"; else i2cstatewr<="1000"; end if; when "1001"=> i2cdata_temp:=i2cda; if i2cdata_temp='1' then i2cstatewr<="1001"; else i2cstatewr<="1010"; end if; when "1010"=> d_cnt:=d_cnt+1; if d_cnt=1 then i2cclk_s<='0'; i2cstatewr<="1010"; elsif d_cnt=delay_cnt then d_cnt:=0; ack_cnt:=ack_cnt+1; if ack_cnt =3 then led<='0'; ack_cnt:=0; i2cstatewr<="0000"; else i_cnt:=8; i2cstatewr<="0011"; end if; else i2cstatewr<="1010"; end if; -- when "1000"=>--i2c stop -- i2cclk_s<='0'; -- i2cda<='0'; -- i2cstatewr<="1001"; -- when "1001"=>-- -- i2cclk_s<='1'; -- i2cstatewr<="1010"; -- when "1010"=> -- i2cda<='1'; -- i2cwr_one:='1'; -- i2cstatewr<="0000"; when others=> i2cstatewr<="0000"; end case; end if; end process;

at24cxx中每片芯片多少页,每页多少字节怎么理解

![图片说明](https://img-ask.csdn.net/upload/201509/16/1442405212_64444.png)

AT24C02的问题,求直接

void SendByte(unsigned char c) { unsigned char BitCnt; for(BitCnt=0;BitCnt<8;BitCnt++) //要传送的数据 长度为8位 { if((c<<BitCnt)&0x80) SDA=1; //判断发送位 else SDA=0; _Nop(); SCL=1; //置时钟线为高,通知被控器开始接收数据位 _Nop(); _Nop(); //保证时钟高电平周期大于4μ _Nop(); _Nop(); _Nop(); SCL=0; } _Nop(); _Nop(); SDA=1; //8位发送完后释放数据线,准备接收应答位 _Nop(); _Nop(); SCL=1; _Nop(); _Nop(); _Nop(); if(SDA==1)ack=0; else ack=1; //判断是否接收到应答信号 SCL=0; _Nop(); _Nop();} 这段是什么意思呢,为什么发送sda,并且scl为什么是从1--0这个过程才能发送sda,还有就是for循环以后是什么意思

当往at24cxx中写一个字节时,这个字节所在页的内容会全部擦除吗

at24cxx是按页擦除的吗,如果我就在某个地址写入一个字节,是不是这个地址所在的也的内容都会被擦除,然后把写入的那个字节写入,那样的话这一页的其他内容就被擦除了,

51单片机关于EEPROM的读和写的问题

```#include "reg52.h" //此文件中定义了单片机的一些特殊功能寄存器 #include"temp.h" #include"i2c.h" typedef unsigned int u16; //对数据类型进行声明定义 typedef unsigned char u8; sbit LSA=P2^2; sbit LSB=P2^3; sbit LSC=P2^4; sbit k1=P3^1; sbit k2=P3^0; sbit k3=P3^2; sbit k4=P3^3; //定义按键端口 int temp; char xianshizhi=0; u16 zhuangtai=0; u8 DisplayData[8]; u8 code smgduan[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f}; /******************************************************************************* * 函 数 名 : delay * 函数功能 : 延时函数,i=1时,大约延时10us *******************************************************************************/ void delay(u16 i) { while(i--); } /******************************************************************************* * 函 数 名 : datapros() * 函数功能 : 温度读取处理转换函数 * 输 入 : temp * 输 出 : 无 *******************************************************************************/ void datapros(int temp) { float tp; if(temp< 0) { DisplayData[0] = 0x40; temp=temp-1; temp=~temp; tp=temp; temp=tp*0.0625*100+0.5; } else { DisplayData[0] = 0x00; tp=temp; temp=tp*0.0625*100+0.5; } DisplayData[1] = smgduan[temp / 10000]; DisplayData[2] = smgduan[temp % 10000 / 1000]; DisplayData[3] = smgduan[temp % 1000 / 100] | 0x80; DisplayData[4] = smgduan[temp % 100 / 10]; DisplayData[5] = smgduan[temp % 10]; } /******************************************************************************* * 函数名 :DigDisplay() * 函数功能 :数码管显示函数 * 输入 : 无 * 输出 : 无 *******************************************************************************/ void DigDisplay() { u8 i; for(i=0;i<6;i++) { switch(i) //位选,选择点亮的数码管, { case(0): LSA=0;LSB=0;LSC=0; break;//显示第0位 case(1): LSA=1;LSB=0;LSC=0; break;//显示第1位 case(2): LSA=0;LSB=1;LSC=0; break;//显示第2位 case(3): LSA=1;LSB=1;LSC=0; break;//显示第3位 case(4): LSA=0;LSB=0;LSC=1; break;//显示第4位 case(5): LSA=1;LSB=0;LSC=1; break;//显示第5位 } P0=DisplayData[5-i];//发送数据 delay(100); //间隔一段时间扫描 P0=0x00;//消隐 } } void Int1Init() { //设置INT1 IT1=1;//跳变沿出发方式(下降沿) EX1=1;//打开INT1的中断允许。 EA=1;//打开总中断 } //这块是按键记忆函数 摁下K1键记忆当前温度值 K2是显示写入EEPROM的温度值 K3是对温度值加1 K4是对当前显示的值清零 //K4的意义后期可以改一下 # void Keypros() { int i=0,j,temp,tp; int num; if(k1==0) { delay(1000); //消抖处理 if(k1==0) { //zhuangtai=0; temp=Ds18b20ReadTemp(); if(temp< 0) { DisplayData[0] = 0x40; temp=temp-1; temp=~temp; tp=temp; temp=tp*0.0625*100+0.5; } else { DisplayData[0] = 0x00; tp=temp; temp=tp*0.0625*100+0.5; } At24c02Write(1,temp); //在地址1内写入数据num } while(!k1); } if(k2==0) { delay(1000); //消抖处理 if(k2==0) { //zhuangtai=2; num=At24c02Read(1); //读取EEPROM地址1内的数据保存在num中 //num=temp; DisplayData[1] = smgduan[num / 10000]; DisplayData[2] = smgduan[num % 10000 / 1000]; DisplayData[3] = smgduan[num % 1000 / 100] | 0x80; DisplayData[4] = smgduan[num % 100 / 10]; DisplayData[5] = smgduan[num% 10]; for(i;i<500;i++){ DigDisplay(); } //Int1Init(); } while(!k2); } } /******************************************************************************* * 函 数 名 : main * 函数功能 : 主函数 * 输 入 : 无 * 输 出 : 无 *******************************************************************************/ void main() { while(1) { datapros(Ds18b20ReadTemp()); //数据处理函数 DigDisplay();//数码管显示函数 Keypros(); } } ``` **接下来是EEPROM函数** #include"i2c.h" /******************************************************************************* * 函数名 : Delay10us() * 函数功能 : 延时10us * 输入 : 无 * 输出 : 无 *******************************************************************************/ void Delay10us() { unsigned char a,b; for(b=1;b>0;b--) for(a=2;a>0;a--); } /******************************************************************************* * 函数名 : I2cStart() * 函数功能 : 起始信号:在SCL时钟信号在高电平期间SDA信号产生一个下降沿 * 输入 : 无 * 输出 : 无 * 备注 : 起始之后SDA和SCL都为0 *******************************************************************************/ void I2cStart() { SDA=1; Delay10us(); SCL=1; Delay10us();//建立时间是SDA保持时间>4.7us SDA=0; Delay10us();//保持时间是>4us SCL=0; Delay10us(); } /******************************************************************************* * 函数名 : I2cStop() * 函数功能 : 终止信号:在SCL时钟信号高电平期间SDA信号产生一个上升沿 * 输入 : 无 * 输出 : 无 * 备注 : 结束之后保持SDA和SCL都为1;表示总线空闲 *******************************************************************************/ void I2cStop() { SDA=0; Delay10us(); SCL=1; Delay10us();//建立时间大于4.7us SDA=1; Delay10us(); } /******************************************************************************* * 函数名 : I2cSendByte(unsigned char dat) * 函数功能 : 通过I2C发送一个字节。在SCL时钟信号高电平期间,保持发送信号SDA保持稳定 * 输入 : num * 输出 : 0或1。发送成功返回1,发送失败返回0 * 备注 : 发送完一个字节SCL=0,SDA=1 *******************************************************************************/ unsigned char I2cSendByte(unsigned char dat) { unsigned char a=0,b=0;//最大255,一个机器周期为1us,最大延时255us。 for(a=0;a<8;a++)//要发送8位,从最高位开始 { SDA=dat>>7; //起始信号之后SCL=0,所以可以直接改变SDA信号 dat=dat<<1; Delay10us(); SCL=1; Delay10us();//建立时间>4.7us SCL=0; Delay10us();//时间大于4us } SDA=1; Delay10us(); SCL=1; while(SDA)//等待应答,也就是等待从设备把SDA拉低 { b++; if(b>200) //如果超过2000us没有应答发送失败,或者为非应答,表示接收结束 { SCL=0; Delay10us(); return 0; } } SCL=0; Delay10us(); return 1; } /******************************************************************************* * 函数名 : I2cReadByte() * 函数功能 : 使用I2c读取一个字节 * 输入 : 无 * 输出 : dat * 备注 : 接收完一个字节SCL=0,SDA=1. *******************************************************************************/ unsigned char I2cReadByte() { unsigned char a=0,dat=0; SDA=1; //起始和发送一个字节之后SCL都是0 Delay10us(); for(a=0;a<8;a++)//接收8个字节 { SCL=1; Delay10us(); dat<<=1; dat|=SDA; Delay10us(); SCL=0; Delay10us(); } return dat; } /******************************************************************************* * 函数名 : void At24c02Write(unsigned char addr,unsigned char dat) * 函数功能 : 往24c02的一个地址写入一个数据 * 输入 : 无 * 输出 : 无 *******************************************************************************/ void At24c02Write(unsigned char addr,unsigned char dat) { I2cStart(); I2cSendByte(0xa0);//发送写器件地址 I2cSendByte(addr);//发送要写入内存地址 I2cSendByte(dat); //发送数据 I2cStop(); } /******************************************************************************* * 函数名 : unsigned char At24c02Read(unsigned char addr) * 函数功能 : 读取24c02的一个地址的一个数据 * 输入 : 无 * 输出 : 无 *******************************************************************************/ unsigned char At24c02Read(unsigned char addr) { unsigned char num; I2cStart(); I2cSendByte(0xa0); //发送写器件地址 I2cSendByte(addr); //发送要读取的地址 I2cStart(); I2cSendByte(0xa1); //发送读器件地址 num=I2cReadByte(); //读取数据 I2cStop(); return num; } ## 程序烧录之后温度能正常显示,可以实现记忆,但是就是无法记忆当前的温度值![图片说明](https://img-ask.csdn.net/upload/201905/24/1558630299_754452.jpg)![图片说明](https://img-ask.csdn.net/upload/201905/24/1558630312_935153.jpg) 请那位大神帮忙看一下Keypros()那块的代码,还有为什么会出现这种情况

java jdk 8 帮助文档 中文 文档 chm 谷歌翻译

JDK1.8 API 中文谷歌翻译版 java帮助文档 JDK API java 帮助文档 谷歌翻译 JDK1.8 API 中文 谷歌翻译版 java帮助文档 Java最新帮助文档 本帮助文档是使用谷

软件测试2小时入门

本课程内容系统、全面、简洁、通俗易懂,通过2个多小时的介绍,让大家对软件测试有个系统的理解和认识,具备基本的软件测试理论基础。 主要内容分为5个部分: 1 软件测试概述,了解测试是什么、测试的对象、原则、流程、方法、模型;&nbsp; 2.常用的黑盒测试用例设计方法及示例演示;&nbsp; 3 常用白盒测试用例设计方法及示例演示;&nbsp; 4.自动化测试优缺点、使用范围及示例‘;&nbsp; 5.测试经验谈。

汽车行驶工况构建2019 D题.zip

1. 标记0与0之间的片段位置 2.标记所之间的毛刺数的位置 3.去掉毛刺数据 速度 并生成 新的数组 4.标记时间段 5. 0与0之间 如果有不连续的时间片段 置零 先找到时间间隔 再看间隔时间对应

Python+OpenCV计算机视觉

Python+OpenCV计算机视觉系统全面的介绍。

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

专为程序员设计的数学课

<p> 限时福利限时福利,<span>15000+程序员的选择!</span> </p> <p> 1、原价 115 元,限时特价仅需 49 元!<br> 2、购课后添加学习助手(微信号:csdnxy68),按提示消息领取编程大礼包!并获取讲师答疑服务! </p> <p> <br> </p> <p> 套餐中一共包含5门程序员必学的数学课程(共47讲) </p> <p> 课程1:《零基础入门微积分》 </p> <p> 课程2:《数理统计与概率论》 </p> <p> 课程3:《代码学习线性代数》 </p> <p> 课程4:《数据处理的最优化》 </p> <p> 课程5:《马尔可夫随机过程》 </p> <p> <br> </p> <p> 哪些人适合学习这门课程? </p> <p> 1)大学生,平时只学习了数学理论,并未接触如何应用数学解决编程问题; </p> <p> 2)对算法、数据结构掌握程度薄弱的人,数学可以让你更好的理解算法、数据结构原理及应用; </p> <p> 3)看不懂大牛代码设计思想的人,因为所有的程序设计底层逻辑都是数学; </p> <p> 4)想学习新技术,如:人工智能、机器学习、深度学习等,这门课程是你的必修课程; </p> <p> 5)想修炼更好的编程内功,在遇到问题时可以灵活的应用数学思维解决问题。 </p> <p> <br> </p> <p> 在这门「专为程序员设计的数学课」系列课中,我们保证你能收获到这些:<br> <br> <span> </span> </p> <p class="ql-long-24357476"> <span class="ql-author-24357476">①价值300元编程课程大礼包</span> </p> <p class="ql-long-24357476"> <span class="ql-author-24357476">②应用数学优化代码的实操方法</span> </p> <p class="ql-long-24357476"> <span class="ql-author-24357476">③数学理论在编程实战中的应用</span> </p> <p class="ql-long-24357476"> <span class="ql-author-24357476">④程序员必学的5大数学知识</span> </p> <p class="ql-long-24357476"> <span class="ql-author-24357476">⑤人工智能领域必修数学课</span> </p> <p> <br> 备注:此课程只讲程序员所需要的数学,即使你数学基础薄弱,也能听懂,只需要初中的数学知识就足矣。<br> <br> 如何听课? </p> <p> 1、登录CSDN学院 APP 在我的课程中进行学习; </p> <p> 2、登录CSDN学院官网。 </p> <p> <br> </p> <p> 购课后如何领取免费赠送的编程大礼包和加入答疑群? </p> <p> 购课后,添加助教微信:<span> csdnxy68</span>,按提示领取编程大礼包,或观看付费视频的第一节内容扫码进群答疑交流! </p> <p> <img src="https://img-bss.csdn.net/201912251155398753.jpg" alt=""> </p>

微信公众平台开发入门

本套课程的设计完全是为初学者量身打造,课程内容由浅入深,课程讲解通俗易懂,代码实现简洁清晰。通过本课程的学习,学员能够入门微信公众平台开发,能够胜任企业级的订阅号、服务号、企业号的应用开发工作。 通过本课程的学习,学员能够对微信公众平台有一个清晰的、系统性的认识。例如,公众号是什么,它有什么特点,它能做什么,怎么开发公众号。 其次,通过本课程的学习,学员能够掌握微信公众平台开发的方法、技术和应用实现。例如,开发者文档怎么看,开发环境怎么搭建,基本的消息交互如何实现,常用的方法技巧有哪些,真实应用怎么开发。

4小时玩转微信小程序——基础入门与微信支付实战

这是一个门针对零基础学员学习微信小程序开发的视频教学课程。课程采用腾讯官方文档作为教程的唯一技术资料来源。杜绝网络上质量良莠不齐的资料给学员学习带来的障碍。 视频课程按照开发工具的下载、安装、使用、程序结构、视图层、逻辑层、微信小程序等几个部分组织课程,详细讲解整个小程序的开发过程

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

IE主页被篡改修复

IE主页修复。IE主页被篡改修复。一键修复IE主页

我说我不会算法,阿里把我挂了。

不说了,字节跳动也反手把我挂了。

土豆SDK(Java版)-非官方

由于土豆SDK一直建设中,最近几天抽空写了一套java的SDK。包含了现有的所有请求协议。本套SDK中仅提供了oAuth的方式(引用oAuth.net的java版示例),并没有在框架中实现,涉及到登录

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

【数据结构与算法综合实验】欢乐连连看(C++ & MFC)案例

这是武汉理工大学计算机学院数据结构与算法综合实验课程的第三次项目:欢乐连连看(C++ & MFC)迭代开发代码。运行环境:VS2017。已经实现功能:开始游戏、消子、判断胜负、提示、重排、计时、帮助。

数学建模竞赛D题“汽车行驶工况构建

第十六届“华为杯”数学建模竞赛D题“汽车行驶工况构建”论文。论文获得比赛国家二等奖,论文为原创,仅供参考。 关键词:数据处理;降维;聚类。

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

Android音视频开发全套

Android平台音视频开发全套,涉及:FFmpeg软解码解码、Mediacodec硬解码编码、Openssl音频播放、OpenGL ES视频渲染、RTMP推流等核心重要知识点。

设计模式(JAVA语言实现)--20种设计模式附带源码

课程亮点: 课程培训详细的笔记以及实例代码,让学员开始掌握设计模式知识点 课程内容: 工厂模式、桥接模式、组合模式、装饰器模式、外观模式、享元模式、原型模型、代理模式、单例模式、适配器模式 策略模式、模板方法模式、观察者模式、迭代器模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式 课程特色: 笔记设计模式,用笔记串连所有知识点,让学员从一点一滴积累,学习过程无压力 笔记标题采用关键字标识法,帮助学员更加容易记住知识点 笔记以超链接形式让知识点关联起来,形式知识体系 采用先概念后实例再应用方式,知识点深入浅出 提供授课内容笔记作为课后复习以及工作备查工具 部分图表(电脑PC端查看):

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

web网页制作期末大作业

分享思维,改变世界. web网页制作,期末大作业. 所用技术:html css javascript 分享所学所得

手把手实现Java图书管理系统(附源码)

【超实用课程内容】 本课程演示的是一套基于Java的SSM框架实现的图书管理系统,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的java人群。详细介绍了图书管理系统的实现,包括:环境搭建、系统业务、技术实现、项目运行、功能演示、系统扩展等,以通俗易懂的方式,手把手的带你从零开始运行本套图书管理系统,该项目附带全部源码可作为毕设使用。 【课程如何观看?】 PC端:https://edu.csdn.net/course/detail/27513 移动端:CSDN 学院APP(注意不是CSDN APP哦) 本课程为录播课,课程2年有效观看时长,大家可以抓紧时间学习后一起讨论哦~ 【学员专享增值服务】 源码开放 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化 下载方式:电脑登录https://edu.csdn.net/course/detail/27513,点击右下方课程资料、代码、课件等打包下载

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

2019 Python开发者日-培训

本次活动将秉承“只讲技术,拒绝空谈”的理念,邀请十余位身处一线的Python技术专家,重点围绕Web开发、自动化运维、数据分析、人工智能等技术模块,分享真实生产环境中使用Python应对IT挑战的真知灼见。此外,针对不同层次的开发者,大会还安排了深度培训实操环节,为开发者们带来更多深度实战的机会。

C++语言基础视频教程

C++语言基础视频培训课程:本课与主讲者在大学开出的程序设计课程直接对接,准确把握知识点,注重教学视频与实践体系的结合,帮助初学者有效学习。本教程详细介绍C++语言中的封装、数据隐藏、继承、多态的实现等入门知识;主要包括类的声明、对象定义、构造函数和析构函数、运算符重载、继承和派生、多态性实现等。 课程需要有C语言程序设计的基础(可以利用本人开出的《C语言与程序设计》系列课学习)。学习者能够通过实践的方式,学会利用C++语言解决问题,具备进一步学习利用C++开发应用程序的基础。

零基础学C#编程—C#从小白到大咖

本课程从初学者角度出发,提供了C#从入门到成为程序开发高手所需要掌握的各方面知识和技术。 【课程特点】 1 由浅入深,编排合理; 2 视频讲解,精彩详尽; 3 丰富实例,轻松易学; 4 每章总结配有难点解析文档。 15大章节,228课时,1756分钟与你一同进步!

编程实现学生基本信息管理程序

编程实现学生基本信息管理程序。学生基本信息包括:学号、姓名、性别、年龄、班级、学院、专业等。具体实现的管理功能如下: (1) 输入并显示多个学生的基本信息; (2) 可根据需要实现学生信息的添加; (

android 漂亮的UI界面 完整的界面设计

声明:这也是我学习时在网上下载的,鉴于分享精神,并且觉得很不错才上传上来的。。。。。 android 漂亮的UI界面 完整的界面设计 这是一个完整的UI设计,但是没写动作,这是一个公司程序员的公司任务

Anaconda详细安装及使用教程(带图文)

Anacond的介绍 Anaconda指的是一个开源的Python发行版本,其包含了conda、Python等180多个科学包及其依赖项。 因为包含了大量的科学包,Anaconda 的下载文件比较大(约 531 MB),如果只需要某些包,或者需要节省带宽或存储空间,也可以使用Miniconda这个较小的发行版(仅包含conda和 Python)。 Conda是一个开源的包、环境管理器,可以用于...

DirectX修复工具V4.0增强版

DirectX修复工具(DirectX Repair)是一款系统级工具软件,简便易用。本程序为绿色版,无需安装,可直接运行。 本程序的主要功能是检测当前系统的DirectX状态,如果发现异常则进行修复

相关热词 c#跨线程停止timer c#批量写入sql数据库 c# 自动安装浏览器 c#语言基础考试题 c# 偏移量打印是什么 c# 绘制曲线图 c#框体中的退出函数 c# 按钮透明背景 c# idl 混编出错 c#在位置0处没有任何行
立即提问