51单片机基础05 实时时钟-思路及代码参考2、3

目录

一、思路二

1、原理图

2、代码

二、思路三

1、原理图

2、代码


一、思路二

所有设定功能相关的操作均在矩阵键盘进行实现,并在定时器中扫描、计数等

1、原理图

2、代码

#include <AT89X52.h>       //调用51单片机的头文件
//---------------------------------------
#define uchar unsigned char
#define uint unsigned int         
//---------------------------------------
     
//---------------------------------------
//1602液晶相关I/O设置
sbit en=P2^3;               //1602液晶的E脚接在P2.3口上
sbit rw=P2^4;              //1602液晶的RW脚接在P2.4口上
sbit rs=P2^5;              //1602液晶的RS脚接在P2.5口上
#define dataPort P0 		//P0口接1602的D0~D7
//---------------------------------------

//4×4矩阵式按键相关I/O设置
//分别为4行和4列的选择线。
sbit HAGN1=P1^0;           //第1行接在P1.0口上
sbit HANG2=P1^1;           //第2行接在P1.1口上
sbit HANB3=P1^2;           //第3行接在P1.2口上
sbit HANG4=P1^3;           //第4行接在P1.3口上
sbit LIE1=P1^4;            //第1列接在P1.4口上
sbit LIE2=P1^5;            //第2列接在P1.5口上
sbit LIE3=P1^6;            //第3列接在P1.6口上
sbit LIE4=P1^7;            //第4列接在P1.7口上
//---------------------------------------

//基本计时功能,具有时分秒
uchar code table[]="0123456789:."; //时间显示
uchar shi=0,fen=0,miao=0;
uchar TIME_FLAG=1;   //时间显示标志位,上电默认显示时间
uchar count=0;		 //定时器值
//---------------------------------------

//秒表功能,最大显示99.9秒
uchar code table1[]=" clock";
uchar code table2[]="ON ";
uchar code table3[]="OFF";
uint TIME_CLK=0;	//秒表显示值
uchar CLK_FLAG=0;   //秒表显示标志位,上电不显示
uchar start_clk_flag=1;   //秒表开始与暂停标志位  默认不暂停
uchar clk=0;		//定时器值
//---------------------------------------

//基本日历显示功能,自动计算闰年及各月对应的日期
uchar code table4[]="0123456789-"; //日期显示
uint nian=2019,yue=11,ri=5;
uchar Calendar_FLAG=0;   //日历显示标志位,上电不显示
//---------------------------------------

//基本闹钟功能与蜂鸣器I/O设置
sbit BEEP=P2^0; 
uchar beep_flag=0;   //闹钟标志位,置1后会五短一长
//---------------------------------------
void delay_ms(uint z)
{
	uint x,y;
	for(x=z;x>0;x--)
	for(y=110;y>0;y--);
}

void lcd_wcom(unsigned char com) //1602写命令函数 
{
	rs=0;				//选择指令寄存器
	rw=0;				//选择写
	dataPort=com;//把命令字送入P0
	delay_ms(5);//延时一小会儿,让1602准备接收数据
	en=1;			//使能线电平变化,命令送入1602的8位数据口
	en=0;
}

void lcd_wdat(unsigned char dat) //1602写数据函数
{
	rs=1;//选择数据寄存器
	rw=0;//选择写
	dataPort=dat;//把要显示的数据送入P2
	delay_ms(5);//延时一小会儿,让1602准备接收数据
	en=1;//使能线电平变化,数据送入1602的8位数据口
	en=0;
}

void lcd_init() //1602初始化函数 
{
	lcd_wcom(0x34);//8位数据,双列,5*7字形 
	//lcd_wcom(0x0c); //开显示屏,关光标,当前字符不闪烁
	lcd_wcom(0x0f);//开启显示屏,开光标,当前字符闪烁
	lcd_wcom(0x06);//显示地址递增,即写一个数据后,显示位置右移一位
	lcd_wcom(0x01);//清屏
	lcd_wcom(0x0C);//清屏	
}


void lcd_clr()   //液晶屏清屏
{
	lcd_wcom(0x01);//清屏
}

void TIME_display()
{
	if(miao==60)
	  {
		miao=0;
		fen++;
	  }
	  if(fen==60)
	  {
	  	fen=0;
		shi++;
	  }
	  if(shi==24)
	 {
		shi=0;
	 } 
	 if(shi!=0)
		 if(fen==0)
		 	if(miao==0)
				beep_flag=1;
	lcd_wcom(0x80);   
	lcd_wdat(table[shi/10]); 	
	lcd_wcom(0x81);  
	lcd_wdat(table[shi%10]); 
	lcd_wcom(0x82);  
	lcd_wdat(table[10]); 

	lcd_wcom(0x83);  
	lcd_wdat(table[fen/10]); 
	lcd_wcom(0x84);  
	lcd_wdat(table[fen%10]); 
	lcd_wcom(0x85);  
	lcd_wdat(table[10]); 

	lcd_wcom(0x86);  
	lcd_wdat(table[miao/10]);
	lcd_wcom(0x87);   
	lcd_wdat(table[miao%10]); 
	lcd_wcom(0x88);  
}

void Clock_display()
{
	if(TIME_CLK==1000) //为1000*0.1故 100秒最大并清零
		TIME_CLK=0;
	if(start_clk_flag==1)
	{
		lcd_wcom(0x80);   
		lcd_wdat(table2[0]);
		lcd_wcom(0x81);   
		lcd_wdat(table2[1]);
		lcd_wcom(0x82);   
		lcd_wdat(table2[2]);
	}
	else if(start_clk_flag==0)
	{
		lcd_wcom(0x80);   
		lcd_wdat(table3[0]);
		lcd_wcom(0x81);   
		lcd_wdat(table3[1]);
		lcd_wcom(0x82);   
		lcd_wdat(table3[2]);
	}
	lcd_wcom(0x85);   
	lcd_wdat(table[TIME_CLK/1000]); 	
	lcd_wcom(0x86);  
	lcd_wdat(table[TIME_CLK/100%10]); 
	lcd_wcom(0x87);  
	lcd_wdat(table[TIME_CLK%100/10]); 
	lcd_wcom(0x88);  
	lcd_wdat(table[11]); 
 	lcd_wcom(0x89);  
	lcd_wdat(table[TIME_CLK%10]); 

}

void Calendar_display()
{
	int a[12]={31,28,31,30,31,30,31,31,30,31,30,31};
	int b[12]={31,29,31,30,31,30,31,31,30,31,30,31};
	if(nian%100==0)
	{	if(nian%4==0)
			if(ri>b[yue])
				{
					ri=1;
					yue+=1;
				}
	}
	else if(nian%4==0)
	{
	if(ri>b[yue])
		{
			ri=1;
			yue+=1;
		}
	}
	else 
	{
	if(ri>a[yue])
		{
			ri=1;
			yue+=1;
		}	
	}	
	if(yue==13)
	{
		yue=1;
		nian+=1;
	}
	lcd_wcom(0x80);   
	lcd_wdat(table4[nian/1000]); 	
	lcd_wcom(0x81);  
	lcd_wdat(table4[nian/100%10]); 
	lcd_wcom(0x82);  
	lcd_wdat(table4[nian%100/10]); 
	lcd_wcom(0x83);  
	lcd_wdat(table4[nian%10]); 
	lcd_wcom(0x84);  
	lcd_wdat(table4[10]); 

	lcd_wcom(0x85);  
	lcd_wdat(table4[yue/10]); 
	lcd_wcom(0x86);  
	lcd_wdat(table4[yue%10]); 
	lcd_wcom(0x87);  
	lcd_wdat(table4[10]); 

	lcd_wcom(0x88);  
	lcd_wdat(table4[ri/10]);
	lcd_wcom(0x89);   
	lcd_wdat(table4[ri%10]); 
	lcd_wcom(0x8A);	 
}

void keyscan()
{
	P1=0xFE;                  //将第一行置零,以扫描K1-K4是否被按下
    if(LIE1==0)
	{
	while(LIE1==0);
	 TIME_FLAG=1;     //时间显示打开,关闭秒表和日历
	 shi=fen=miao=0;
	 CLK_FLAG=Calendar_FLAG=0;
	lcd_clr();   //先清屏
	}		                            
    else if(LIE2==0) {	while(LIE2==0);shi++;} 
    else if(LIE3==0) {	while(LIE3==0);fen++;}		                           
    else if(LIE4==0) {	while(LIE4==0);miao++;} 		                            

    P1=0xFD;                  //将第二行置零,以扫描K5-K8是否被按下
    if(LIE1==0) 	
	{
	while(LIE1==0);
	lcd_clr();   //先清屏
	 TIME_CLK=0;
	 CLK_FLAG=1;     //秒表打开,关闭时间和日历
	 TIME_FLAG=Calendar_FLAG=0;
	}
    else if(LIE2==0) {while(LIE2==0); start_clk_flag=1; }//开启计数	  
    else if(LIE3==0) {while(LIE3==0); start_clk_flag=0;} //暂停计数
    else if(LIE4==0) 
	{
	 while(LIE4==0);
     lcd_clr();   //先清屏
	 CLK_FLAG=TIME_FLAG=0;     //秒表关闭
	 Calendar_FLAG=1;		  //默认打开日历
	 nian=2021;
	 yue=11;
	 ri=5;
	}

    P1=0xFB;                  //将第三行置零,以扫描K9-K12是否被按下
    if(LIE1==0)	
	{
     lcd_clr();   //先清屏
	 while(LIE1==0);
	 CLK_FLAG=TIME_FLAG=0;     //关闭其他
	 Calendar_FLAG=1;		  //打开日历
	 nian=2019;
	 yue=11;
	 ri=5;
	}
    else if(LIE2==0) {while(LIE2==0);nian++; }//如果K10键按下,KEYbuf赋值写9
    else if(LIE3==0) {while(LIE3==0);yue++;}//如果K11键按下,KEYbuf赋值写10
    else if(LIE4==0) {while(LIE4==0);ri++;}//如果K12键按下,KEYbuf赋值写11

//        P1=0xF7;                  //将第四行置零,以扫描K13-K16是否被按下
//        if(LIE1==0) KEYbuf=12;    //如果K13键按下,KEYbuf赋值写12
//        else if(LIE2==0) KEYbuf=13;//如果K14键按下,KEYbuf赋值写13
//        else if(LIE3==0) KEYbuf=14;//如果K15键按下,KEYbuf赋值写14
//        else if(LIE4==0) KEYbuf=15;//如果K16键按下,KEYbuf赋值写15				
}

uchar beep_on()
{
	if(beep_flag==0)
		return 1;
	BEEP=0;
	delay_ms(50);
	BEEP=1;
	delay_ms(50);
	if(beep_flag==0)
		return 1;
	BEEP=0;
	delay_ms(50);
	BEEP=1;
	delay_ms(50);
	if(beep_flag==0)
		return 1;
	BEEP=0;
	delay_ms(50);
	if(beep_flag==0)
		return 1;
	BEEP=1;
	delay_ms(50);
	if(beep_flag==0)
		return 1;
	BEEP=0;
	delay_ms(50);
	BEEP=1;
	delay_ms(50);
	if(beep_flag==0)
		return 1;
	BEEP=0;
	delay_ms(50);
	BEEP=1;
	delay_ms(50);
	if(beep_flag==0)
		return 1;
	BEEP=0;
	delay_ms(1000);
	BEEP=1;
	delay_ms(1000);
	beep_flag=0;
	return 1;
}
void time_init()
{
    TMOD  |=0x01;
	IT0=1;     //INT0负跳变沿触发
	EX0=1;     //外部中断0使能
    TH0=(65536-49000)/256;
    TL0=(65536-49000)%256;	 //50000us,50ms一次中断
    TR0=1;
    ET0=1;
    EA=1;
}

void api()
{
	uchar i=0;
	if(TIME_FLAG==1)
	{
	  TIME_display();
	  if(beep_flag==1)	
		 beep_on();
	  BEEP=1;
	}
	else if(CLK_FLAG==1)
	{
	  Clock_display();
	}
	else if(Calendar_FLAG==1) 
	{
	  Calendar_display();
	}
}
void main(void)            //主函数,单片机开机后就是从这个函数开始运行
{

		lcd_init(); 	//液晶初始化
 		time_init();	 //定时器与中断配置
		while(1)
		{
			api();
		}
}

void T0_ISR(void) interrupt 1
{
	uchar i=0;
	TH0=(65536-49000)/256;
	TL0=(65536-49000)%256;
	keyscan();	
	if(TIME_FLAG==1)
	{
	 	count++;
	 	if(count==18)
	  	{
	  	 count=0;
	  	 miao++;
 		}
	}
	else if((CLK_FLAG==1)&&(start_clk_flag==1))
	{
	 	clk++;
	 	if(clk==2)
	  	{
	  	 clk=0;
		 TIME_CLK++;
 		}
	}

}

void INT0_ISR(void) interrupt 0
{
	EX0=0;
	delay_ms(1);
	if(0==P3_2)
	{
	  beep_flag=0;   //外部中断高优先级控制蜂鸣器标志位
	  BEEP=1;    //关闭蜂鸣器
	}
	IE0=0;
	EX0=1;
}

二、思路三

通过数码管显示、矩阵键盘扫描按键功能。

1、原理图

2、代码

相对思路二而言,仅修改了显示的方式,其他都没有改变。

#include <AT89X52.h>       //调用51单片机的头文件
#define uint unsigned int
#define uchar unsigned char

//---------------------------------------

//4×4矩阵式按键相关I/O设置
//分别为4行和4列的选择线。
sbit HAGN1=P1^0;           //第1行接在P1.0口上
sbit HANG2=P1^1;           //第2行接在P1.1口上
sbit HANB3=P1^2;           //第3行接在P1.2口上
sbit HANG4=P1^3;           //第4行接在P1.3口上
sbit LIE1=P1^4;            //第1列接在P1.4口上
sbit LIE2=P1^5;            //第2列接在P1.5口上
sbit LIE3=P1^6;            //第3列接在P1.6口上
sbit LIE4=P1^7;            //第4列接在P1.7口上
//---------------------------------------

//基本计时功能,具有时分秒
uint shi=0,fen=0,miao=0;
uint TIME_FLAG=1;   //时间显示标志位,上电默认显示时间
uint count=0;		 //定时器值
//---------------------------------------

//秒表功能,最大显示99.9秒

uint TIME_CLK=0;	//秒表显示值
uint CLK_FLAG=0;   //秒表显示标志位,上电不显示
uint start_clk_flag=1;   //秒表开始与暂停标志位  默认不暂停
uint clk=0;		//定时器值
//---------------------------------------

//基本日历显示功能,自动计算闰年及各月对应的日期

uint nian=2019,yue=11,ri=5;
uint Calendar_FLAG=0;   //日历显示标志位,上电不显示
//---------------------------------------

//基本闹钟功能与蜂鸣器I/O设置
sbit BEEP=P3^7; 
uint beep_flag=0;   //闹钟标志位,置1后会五短一长
//---------------------------------------

//---------------------------------------
//8位数码管相关I/O设置
//P2.0-P2.2为3-8译码器U16的3个输入,P2=0x00 0x01 0x02 0x03最大为 0x07
//可以不用定义三个位,直接写P2=0X即可    
//数码管字形表,供显示时查询
unsigned char code LED1[12]=
{                          //定义表格一定要使用code,这样会做到程序存储区中
    0x3F,                  //"0"的字形表,0B00111111
    0x06,                  //"1"的字形表,0B00000110
    0x5B,                  //"2"的字形表,0B01011011
    0x4F,                  //"3"的字形表,0B01001111
    0x66,                  //"4"的字形表,0B01100110
    0x6D,                  //"5"的字形表,0B01101101
    0x7D,                  //"6"的字形表,0B01111101
    0x07,                  //"7"的字形表,0B00000111
    0x7F,                  //"8"的字形表,0B01111111
    0x6F,                  //"9"的字形表,0B01101111
	0x40,				   //"-"的字形表,0B01000000
	0x80,				   //"-"的字形表,0B01000000
};  
unsigned char code LED2[12]=
{                          //定义表格一定要使用code,这样会做到程序存储区中
    0xBF,                  //"0"的字形表,0B10111111
    0x86,                  //"1"的字形表,0B10000110
    0xDB,                  //"2"的字形表,0B11011011
    0xCF,                  //"3"的字形表,0B11001111
    0xE6,                  //"4"的字形表,0B11100110
    0xED,                  //"5"的字形表,0B11101101
    0xFD,                  //"6"的字形表,0B11111101
    0x87,                  //"7"的字形表,0B10000111
    0xFF,                  //"8"的字形表,0B11111111
    0xEF,                  //"9"的字形表,0B11101111
	0xC0,				   //"-"的字形表,0B11000000
}; 
  
//---------------------------------------
void delay_ms(uint z)
{
	uint x,y;
	for(x=z;x>0;x--)
	for(y=110;y>0;y--);
}

//x为段选数据,y为位选0x00 0x01 0x02 0x03最大为 0x07
void tube_display(uint x,uint y,uint z)
{
 	P2=y;
	if(z==1)
	P0=LED1[x];
	else if(z==2)
	P0=LED2[x];
}

//x为段选数据,y为位选0x00 0x01 0x02 0x03最大为 0x07
void TIME_display()
{
	if(miao==60)
	  {
		miao=0;
		fen++;
	  }
	  if(fen==60)
	  {
	  	fen=0;
		shi++;
	  }
	  if(shi==24)
	 {
		shi=0;
	 } 
	 if(shi!=0)
		 if(fen==0)
		 	if(miao==0)
				beep_flag=1; 
	tube_display(shi/10,0,1); 	
	delay_ms(5);
	tube_display(shi%10,1,1); 	
	delay_ms(5);
	tube_display(10,2,1); 	
	delay_ms(5);

	tube_display(fen/10,3,1); 	
	delay_ms(5);
	tube_display(fen%10,4,1); 	
	delay_ms(5);
	tube_display(10,5,1); 	
	delay_ms(5);
	
	tube_display(miao/10,6,1); 	
	delay_ms(5);
	tube_display(miao%10,7,1); 	
	delay_ms(5);

}
uchar beep_on()
{
	if(beep_flag==0)
		return 1;
	BEEP=0;
	delay_ms(50);
	BEEP=1;
	delay_ms(50);
	if(beep_flag==0)
		return 1;
	BEEP=0;
	delay_ms(50);
	BEEP=1;
	delay_ms(50);
	if(beep_flag==0)
		return 1;
	BEEP=0;
	delay_ms(50);
	if(beep_flag==0)
		return 1;
	BEEP=1;
	delay_ms(50);
	if(beep_flag==0)
		return 1;
	BEEP=0;
	delay_ms(50);
	BEEP=1;
	delay_ms(50);
	if(beep_flag==0)
		return 1;
	BEEP=0;
	delay_ms(50);
	BEEP=1;
	delay_ms(50);
	if(beep_flag==0)
		return 1;
	BEEP=0;
	delay_ms(1000);
	BEEP=1;
	delay_ms(1000);
	beep_flag=0;
	return 1;
}
void Clock_display()
{
	if(TIME_CLK==1000) //为1000*0.1故 100秒最大并清零
		TIME_CLK=0;

	tube_display(TIME_CLK/1000,0,1); 	
	delay_ms(5);
	tube_display(TIME_CLK/100%10,1,1); 	
	delay_ms(5);
	tube_display(TIME_CLK%100/10,2,2); 	
	delay_ms(5);
	tube_display(TIME_CLK%10,3,1); 	
	delay_ms(5);
}
void Calendar_display()
{
	int a[12]={31,28,31,30,31,30,31,31,30,31,30,31};
	int b[12]={31,29,31,30,31,30,31,31,30,31,30,31};
	if(nian%100==0)
	{	if(nian%4==0)
			if(ri>b[yue])
				{
					ri=1;
					yue+=1;
				}
	}
	else if(nian%4==0)
	{
	if(ri>b[yue])
		{
			ri=1;
			yue+=1;
		}
	}
	else 
	{
	if(ri>a[yue])
		{
			ri=1;
			yue+=1;
		}	
	}	
	if(yue==13)
	{
		yue=1;
		nian+=1;
	}
	tube_display(nian/1000,0,1); 	
	delay_ms(5);
	tube_display(nian/100%10,1,1); 	
	delay_ms(5);
	tube_display(nian%100/10,2,1); 	
	delay_ms(5);
	tube_display(nian%10,3,2); 	
	delay_ms(5);

	tube_display(yue/10,4,1); 	
	delay_ms(5);
	tube_display(yue%10,5,2); 	
	delay_ms(5);

	tube_display(ri/10,6,1); 	
	delay_ms(5);
	tube_display(ri%10,7,1); 	
	delay_ms(5);  
}

void keyscan()
{
	P1=0xFE;                  //将第一行置零,以扫描K1-K4是否被按下
    if(LIE1==0)
	{
	while(LIE1==0);
	 TIME_FLAG=1;     //时间显示打开,关闭秒表和日历
	 shi=fen=miao=0;
	 CLK_FLAG=Calendar_FLAG=0;
	}		                            
    else if(LIE2==0) {	while(LIE2==0);shi++;} 
    else if(LIE3==0) {	while(LIE3==0);fen++;}		                           
    else if(LIE4==0) {	while(LIE4==0);miao++;} 		                            

    P1=0xFD;                  //将第二行置零,以扫描K5-K8是否被按下
    if(LIE1==0) 	
	{
	while(LIE1==0);
	 TIME_CLK=0;
	 CLK_FLAG=1;     //秒表打开,关闭时间和日历
	 TIME_FLAG=Calendar_FLAG=0;
	}
    else if(LIE2==0) {while(LIE2==0); start_clk_flag=1; }//开启计数	  
    else if(LIE3==0) {while(LIE3==0); start_clk_flag=0;} //暂停计数
    else if(LIE4==0) 
	{
	 while(LIE4==0);
	 CLK_FLAG=TIME_FLAG=0;     //秒表关闭
	 Calendar_FLAG=1;		  //默认打开日历
	 nian=2021;
	 yue=11;
	 ri=5;
	}

    P1=0xFB;                  //将第三行置零,以扫描K9-K12是否被按下
    if(LIE1==0)	
	{
	 while(LIE1==0);
	 CLK_FLAG=TIME_FLAG=0;     //关闭其他
	 Calendar_FLAG=1;		  //打开日历
	 nian=2019;
	 yue=11;
	 ri=5;
	}
    else if(LIE2==0) {while(LIE2==0);nian++; }//如果K10键按下,KEYbuf赋值写9
    else if(LIE3==0) {while(LIE3==0);yue++;}//如果K11键按下,KEYbuf赋值写10
    else if(LIE4==0) {while(LIE4==0);ri++;}//如果K12键按下,KEYbuf赋值写11				
}

void api()
{
	if(TIME_FLAG==1)
	{
	  TIME_display();

	  BEEP=1;
	}
	else if(CLK_FLAG==1)
	{
	  Clock_display();
	}
	else if(Calendar_FLAG==1) 
	{
	  Calendar_display();
	}
}
void time_init()
{
    TMOD  |=0x01;
	IT0=1;     //INT0负跳变沿触发
	EX0=1;     //外部中断0使能
    TH0=(65536-49000)/256;
    TL0=(65536-49000)%256;	 //50000us,50ms一次中断
    TR0=1;
    ET0=1;
    EA=1;
}
void main(void)            //主函数,单片机开机后就是从这个函数开始运行
{
 	time_init();	 //定时器与中断配置
    while(1)               //死循环,单片机初始化后,将一直运行这个死循环
    {
        keyscan();
		if(beep_flag==1)	
		 {
		 beep_on();
	     BEEP=1;    //关闭蜂鸣器
		 }
    }
}

void T0_ISR(void) interrupt 1
{
	uchar i=0;
	TH0=(65536-49000)/256;
	TL0=(65536-49000)%256;
	if(TIME_FLAG==1)
	{
	 	count++;
	 	if(count==20)
	  	{
	  	 count=0;
	  	 miao++;
 		}
	}
	else if((CLK_FLAG==1)&&(start_clk_flag==1))
	{
	 	clk++;
	 	if(clk==2)
	  	{
	  	 clk=0;
		 TIME_CLK++;
 		}
	}
	api();
}

void INT0_ISR(void) interrupt 0
{
	EX0=0;
	delay_ms(1);
	if(0==P3_2)
	{
	  beep_flag=0;   //外部中断高优先级控制蜂鸣器标志位
	  BEEP=1;    //关闭蜂鸣器
	}
	IE0=0;
	EX0=1;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/917915.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Notepad++的完美替代

由于Notepad的作者曾发表过可能在开发者代码中植入恶意软件的言论&#xff0c;他备受指责。在此&#xff0c;我向大家推荐一个Notepad的完美替代品——NotepadNext和Notepad--。 1、NotepadNext NotepadNext的特点&#xff1a; 1、跨平台兼容性 NotepadNext基于Electron或Qt…

Python | Leetcode Python题解之第564题数组嵌套

题目&#xff1a; 题解&#xff1a; class Solution:def arrayNesting(self, nums: List[int]) -> int:ans, n 0, len(nums)for i in range(n):cnt 0while nums[i] < n:num nums[i]nums[i] ni numcnt 1ans max(ans, cnt)return ans

面试经典 150 题:20、2、228、122

20. 有效的括号 参考代码 #include <stack>class Solution { public:bool isValid(string s) {if(s.size() < 2){ //特判&#xff1a;空字符串和一个字符的情况return false;}bool flag true;stack<char> st; //栈for(int i0; i<s.size(); i){if(s[i] ( |…

使用vscode+expo+Android夜神模拟器运行react-native项目

1.进入夜神模拟器安装路径下的bin目录 2.输入命令&#xff0c;连接Android Studio 启动夜神模拟器后&#xff0c; 打开安装目录的bin文件夹执行下面的命令&#xff0c;只需执行一次&#xff09; nox_adb.exe connect 127.0.0.1:62001adb connect 127.0.0.1:62001 3.运行项目…

【STM32】USB 简要驱动软件架构图

STM32 USB 软件架构比较复杂&#xff0c;建议去看 UM 1734 或者 st wiki STM32 USB call graph STM32 USB Device Library files organization Reference [1]: https://wiki.stmicroelectronics.cn/stm32mcu/wiki/Introduction_to_USB_with_STM32 [2]: UM1734

鸿蒙中如何实现图片拉伸效果

2024年10月22日&#xff0c;华为发布会上&#xff0c;推出鸿蒙5.0。现在加入恰逢时机&#xff0c;你&#xff0c;我皆是鸿蒙时代合伙人。无论为了学习技术&#xff0c;还是为了谋福利&#xff0c;在鸿蒙的浩瀚海洋中分到一杯羹。现在学习鸿蒙正当时。 一文了解鸿蒙中图片拉伸的…

VUE+SPRINGBOOT实现邮箱注册、重置密码、登录功能

随着互联网的发展&#xff0c;网站用户的管理、触达、消息通知成为一个网站设计是否合理的重要标志。目前主流互联网公司都支持手机验证码注册、登录。但是手机短信作为服务端网站是需要付出运营商通信成本的&#xff0c;而邮箱的注册、登录、重置密码&#xff0c;无疑成为了这…

网络基础(4)传输层

既然是传输层首先就要明确实在层状结构的哪里,除开物理层之外分成了四层协议: 到这里上层(应用层)的使用已经没有问题&#xff0c;之前使用的套接字都是在应用层的。 再说端口号 到一个主机收到一个报文的时候&#xff0c;这个报文中一定存在这个报文需要到的主机的ip号。如果…

web——sqliabs靶场——第六关——报错注入和布尔盲注

这一关还是使用报错注入和布尔盲注 一. 判断是否有sql注入 二. 判断注入的类型 是双引号的注入类型。 3.报错注入的检测 可以使用sql报错注入 4.查看库名 5. 查看表名 6.查看字段名 7. 查具体字段的内容 结束 布尔盲注 结束

网络基础 - 网段划分篇

我们知道&#xff0c;IP 地址(IPv4 地址)由 “网络标识(网络地址)” 和 “主机标识(主机地址)” 两部分组成&#xff0c;例如 192.168.128.10/24&#xff0c;其中的 “/24” 表示从第 1 位开始到多少位属于网络标识&#xff0c;那么&#xff0c;剩余位就属于主机标识了&#xf…

【AI图像生成网站Golang】JWT认证与令牌桶算法

AI图像生成网站 目录 一、项目介绍 二、雪花算法 三、JWT认证与令牌桶算法 四、项目架构 五、图床上传与图像生成API搭建 六、项目测试与调试(等待更新) 三、JWT认证与令牌桶算法 在现代后端开发中&#xff0c;用户认证和接口限流是确保系统安全性和性能的两大关键要素…

TR3:Pytorch复现Transformer

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 一、实验目的 从整体上把握Transformer模型&#xff0c;明白它是个什么东西&#xff0c;可以干嘛读懂Transformer的复现代码 二、实验环境 语言环境&#xff1…

数据分布之指数分布(sample database classicmodels _No.10)

数据分布之指数分布&#xff08;sample database classicmodels _No.10&#xff09; 准备工作&#xff0c;可以去下载 classicmodels 数据库具体如下 点击&#xff1a;classicmodels 也可以去 下面我的博客资源下载 https://download.csdn.net/download/tomxjc/88685970 文章…

无人机动力系统测试-实测数据与CFD模拟仿真数据关联对比分析

我们经常被问到这样的问题&#xff1a;“我们计划运行 CFD 仿真&#xff0c;我们还需要对电机和螺旋桨进行实验测试吗&#xff1f;我们可能有偏见&#xff0c;但我们的答案始终是肯定的&#xff0c;而且有充分的理由。我们自己执行了大量的 CFD 仿真&#xff0c;但我们承认&…

MinIO 的 S3 over RDMA 计划: 为高速人工智能数据基础设施设定对象存储新标准

随着 AI 和机器学习的需求不断加速&#xff0c;数据中心网络正在迅速发展以跟上步伐。对于许多企业来说&#xff0c;400GbE 甚至 800GbE 正在成为标准选择&#xff0c;因为数据密集型和时间敏感型 AI 工作负载需要高速、低延迟的数据传输。用于大型语言处理、实时分析和计算机视…

游戏引擎学习第13天

视频参考:https://www.bilibili.com/video/BV1QQUaYMEEz/ 改代码的地方尽量一张图说清楚吧,懒得浪费时间 game.h #pragma once #include <cmath> #include <cstdint> #include <malloc.h>#define internal static // 用于定义内翻译单元内部函数 #…

十分钟学会html超文本标记语言

前言 本次学习的是在b站up主泷羽sec课程有感而发&#xff0c;如涉及侵权马上删除文章。 笔记的只是方便各位师傅学习知识&#xff0c;以下网站只涉及学习内容&#xff0c;其他的都与本人无关&#xff0c;切莫逾越法律红线&#xff0c;否则后果自负。 &#xff01;&#xff01;…

【Linux系统编程】第四十七弹---深入探索:POSIX信号量与基于环形队列的生产消费模型实现

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】 目录 1、POSIX信号量 2、基于环形队列的生产消费模型 2.1、代码实现 2.1.1、RingQueue基本结构 2.1.2、PV操作 2.1.3、构造析构…

除了 TON, 哪些公链在争夺 Telegram 用户?数据表现如何?

作者&#xff1a;Stella L (stellafootprint.network) 在 2024 年&#xff0c;区块链游戏大规模采用迎来了一个意想不到的催化剂&#xff1a;Telegram。随着各大公链争相布局这个拥有海量用户基础的即时通讯平台&#xff0c;一个核心问题浮出水面&#xff1a;这种用户获取策略…

小白进!QMK 键盘新手入门指南

经常玩键盘的伙伴应该都知道&#xff0c;现在的键盘市场可谓是百花齐放&#xff0c;已经不是之前的单一功能产品化时代。我们可以看到很多诸如&#xff1a;机械轴键盘、磁轴键盘、光轴键盘、电感轴键盘&#xff0c;以及可能会上市的光磁轴键盘&#xff0c;更有支持屏幕的、带旋…