当前位置: 首页 > news >正文

51单片机使用定时器实现LCD1602的时间显示(STC89C52RC)

本文前半部分直接给出实现(注意进位问题是秒->分->小时,用 if 嵌套即可实现),后半部分讲解定时器和中断系统。

 效果展示:

 

LCD1602电路图: 

项目结构: 

代码实现: 

main.c 

#include <REGX52.H>    //包含51单片机寄存器定义头文件
#include "LCD1602.h"   // 包含LCD1602液晶驱动头文件
#include "Timer0.h"    // 包含定时器T0驱动头文件// 定义时间变量并初始化(23:59:57)
unsigned int Hour = 23;  
unsigned int Min = 59;   
unsigned int Sec = 57;  void main() {LCD_Init();      // 初始化LCD1602液晶显示屏Timer0Init();    // 初始化定时器T0// 在LCD上显示静态文本LCD_ShowString(1, 1, "Clock:");  // 第1行第1列显示"Clock:"LCD_ShowString(2, 3, ":");       // 第2行第3列显示冒号(分隔小时和分钟)LCD_ShowString(2, 6, ":");       // 第2行第6列显示冒号(分隔分钟和秒钟)while(1) {// 持续更新时间显示(动态刷新)LCD_ShowNum(2, 1, Hour, 2);  // 第2行第1列显示2位小时数LCD_ShowNum(2, 4, Min, 2);   // 第2行第4列显示2位分钟数LCD_ShowNum(2, 7, Sec, 2);   // 第2行第7列显示2位秒钟数}
}// 定时器T0中断服务函数(中断号1)
void Timer0_Routine() interrupt 1 {static unsigned int T0Count;  // 静态变量,用于计数中断次数// 重新装载定时器初值(配置为1ms中断一次,实际需根据晶振频率计算)TL0 = 0x66;  // 定时器低位初值TH0 = 0xFC;  // 定时器高位初值T0Count++;  // 中断次数计数器自增// 当计数达到1000次(约1秒)时更新时间if(T0Count >= 1000) {T0Count = 0;  // 重置计数器Sec++;         // 秒钟加1// 时间进位处理if(Sec >= 60) {     // 超过59秒Sec = 0;        // 秒钟归零Min++;          // 分钟加1if(Min >= 60) { // 超过59分钟Min = 0;    // 分钟归零Hour++;     // 小时加1if(Hour >= 24) { // 超过23小时Hour = 0;    // 小时归零}}}}
}

LCD1602.h 

#ifndef __LCD1602_H__
#define __LCD1602_H__//用户调用函数:
void LCD_Init();
void LCD_ShowChar(unsigned char Line,unsigned char Column,char Char);
void LCD_ShowString(unsigned char Line,unsigned char Column,char *String);
void LCD_ShowNum(unsigned char Line,unsigned char Column,unsigned int Number,unsigned char Length);
void LCD_ShowSignedNum(unsigned char Line,unsigned char Column,int Number,unsigned char Length);
void LCD_ShowHexNum(unsigned char Line,unsigned char Column,unsigned int Number,unsigned char Length);
void LCD_ShowBinNum(unsigned char Line,unsigned char Column,unsigned int Number,unsigned char Length);#endif

LCD1602.c 

#include <REGX52.H>//引脚配置:
sbit LCD_RS=P2^6;
sbit LCD_RW=P2^5;
sbit LCD_EN=P2^7;
#define LCD_DataPort P0//函数定义:
/*** @brief  LCD1602延时函数,12MHz调用可延时1ms* @param  无* @retval 无*/
void LCD_Delay()
{unsigned char i, j;i = 2;j = 239;do{while (--j);} while (--i);
}/*** @brief  LCD1602写命令* @param  Command 要写入的命令* @retval 无*/
void LCD_WriteCommand(unsigned char Command)
{LCD_RS=0;LCD_RW=0;LCD_DataPort=Command;LCD_EN=1;LCD_Delay();LCD_EN=0;LCD_Delay();
}/*** @brief  LCD1602写数据* @param  Data 要写入的数据* @retval 无*/
void LCD_WriteData(unsigned char Data)
{LCD_RS=1;LCD_RW=0;LCD_DataPort=Data;LCD_EN=1;LCD_Delay();LCD_EN=0;LCD_Delay();
}/*** @brief  LCD1602设置光标位置* @param  Line 行位置,范围:1~2* @param  Column 列位置,范围:1~16* @retval 无*/
void LCD_SetCursor(unsigned char Line,unsigned char Column)
{if(Line==1){LCD_WriteCommand(0x80|(Column-1));}else if(Line==2){LCD_WriteCommand(0x80|(Column-1+0x40));}
}/*** @brief  LCD1602初始化函数* @param  无* @retval 无*/
void LCD_Init()
{LCD_WriteCommand(0x38);//八位数据接口,两行显示,5*7点阵LCD_WriteCommand(0x0c);//显示开,光标关,闪烁关LCD_WriteCommand(0x06);//数据读写操作后,光标自动加一,画面不动LCD_WriteCommand(0x01);//光标复位,清屏
}/*** @brief  在LCD1602指定位置上显示一个字符* @param  Line 行位置,范围:1~2* @param  Column 列位置,范围:1~16* @param  Char 要显示的字符* @retval 无*/
void LCD_ShowChar(unsigned char Line,unsigned char Column,char Char)
{LCD_SetCursor(Line,Column);LCD_WriteData(Char);
}/*** @brief  在LCD1602指定位置开始显示所给字符串* @param  Line 起始行位置,范围:1~2* @param  Column 起始列位置,范围:1~16* @param  String 要显示的字符串* @retval 无*/
void LCD_ShowString(unsigned char Line,unsigned char Column,char *String)
{unsigned char i;LCD_SetCursor(Line,Column);for(i=0;String[i]!='\0';i++){LCD_WriteData(String[i]);}
}/*** @brief  返回值=X的Y次方*/
int LCD_Pow(int X,int Y)
{unsigned char i;int Result=1;for(i=0;i<Y;i++){Result*=X;}return Result;
}/*** @brief  在LCD1602指定位置开始显示所给数字* @param  Line 起始行位置,范围:1~2* @param  Column 起始列位置,范围:1~16* @param  Number 要显示的数字,范围:0~65535* @param  Length 要显示数字的长度,范围:1~5* @retval 无*/
void LCD_ShowNum(unsigned char Line,unsigned char Column,unsigned int Number,unsigned char Length)
{unsigned char i;LCD_SetCursor(Line,Column);for(i=Length;i>0;i--){LCD_WriteData(Number/LCD_Pow(10,i-1)%10+'0');}
}/*** @brief  在LCD1602指定位置开始以有符号十进制显示所给数字* @param  Line 起始行位置,范围:1~2* @param  Column 起始列位置,范围:1~16* @param  Number 要显示的数字,范围:-32768~32767* @param  Length 要显示数字的长度,范围:1~5* @retval 无*/
void LCD_ShowSignedNum(unsigned char Line,unsigned char Column,int Number,unsigned char Length)
{unsigned char i;unsigned int Number1;LCD_SetCursor(Line,Column);if(Number>=0){LCD_WriteData('+');Number1=Number;}else{LCD_WriteData('-');Number1=-Number;}for(i=Length;i>0;i--){LCD_WriteData(Number1/LCD_Pow(10,i-1)%10+'0');}
}/*** @brief  在LCD1602指定位置开始以十六进制显示所给数字* @param  Line 起始行位置,范围:1~2* @param  Column 起始列位置,范围:1~16* @param  Number 要显示的数字,范围:0~0xFFFF* @param  Length 要显示数字的长度,范围:1~4* @retval 无*/
void LCD_ShowHexNum(unsigned char Line,unsigned char Column,unsigned int Number,unsigned char Length)
{unsigned char i,SingleNumber;LCD_SetCursor(Line,Column);for(i=Length;i>0;i--){SingleNumber=Number/LCD_Pow(16,i-1)%16;if(SingleNumber<10){LCD_WriteData(SingleNumber+'0');}else{LCD_WriteData(SingleNumber-10+'A');}}
}/*** @brief  在LCD1602指定位置开始以二进制显示所给数字* @param  Line 起始行位置,范围:1~2* @param  Column 起始列位置,范围:1~16* @param  Number 要显示的数字,范围:0~1111 1111 1111 1111* @param  Length 要显示数字的长度,范围:1~16* @retval 无*/
void LCD_ShowBinNum(unsigned char Line,unsigned char Column,unsigned int Number,unsigned char Length)
{unsigned char i;LCD_SetCursor(Line,Column);for(i=Length;i>0;i--){LCD_WriteData(Number/LCD_Pow(2,i-1)%2+'0');}
}

Timer0.h 

#ifndef __TIMER0_H__
#ifndef __TIMER0_H__void Timer0Init(void);
#endif

Timer0.c 

#include <REGX52.H>/*** @brief  定时器0初始化,1毫秒@11.0592MHZ* @param 	无* @retval 无*/
void Timer0Init(void)		//1毫秒@11.0592MHz
{TMOD &= 0xF0;		//清零低4位(对应定时器0的配置),保留高4位(定时器1的配置)不变TMOD |= 0x01;		//设置定时器0为模式1(二进制0000 0001中的低4位),即16位定时器模式TL0 = 0x66;		//设置定时初值TH0 = 0xFC;		//设置定时初值TF0 = 0;		//清除定时器0溢出标志位,防止初始化后立即触发中断TR0 = 1;		//启动定时器0,开始计数ET0=1;			//开启定时器0中断(ET0)和全局中断(EA),允许中断触发			EA=1;PT0=0;			//设置定时器0中断优先级为低优先级
}//定时器通用模板
//void Timer0_Routine() interrupt 1{
//	static unsigned int T0Count;
//	TL0 = 0x66;		//设置定时初值
//	TH0 = 0xFC;		//设置定时初值
//	T0Count++;
//	if(T0Count>=1000)
//	{
//		T0Count=0;
//	}
//}

定时器和中断系统: 

1.定时器

定时器介绍:51单片机定时器属于单片机的内部资源,其电连接和运转均在单片机内部完成。

定时器的作用:

  • 基于时钟信号计数,提供精准的时间基准(如微秒/毫秒级延时)
  • 替代长时间的Delay,提高CPU的运行效率和处理速度
  • 当计数值达到预设阈值时,触发中断,执行特定任务(如周期任务调度)
  • 通过调节占空比和频率,输出脉宽调制信号(PWM)

STC89C52定时器资源:

  • 定时器个数:3个(T0、T1、T2),T0和T1与传统的51单片机兼容,T2是此型号单片机增加的资源
  • 注意:定时器的资源和单片机的型号是关联在一起的,不同的型号可能会有不同的定时器个数和操作方式,但一般来说,T0和T1的操作方式是所有51单片机所共有的

定时器工作原理框图:

  • 定时器在单片机的内部就像一个小闹钟一样,根据时钟的输出信号,每隔"一秒",计数单元的数值就增加一,当计数单元数值增加到"设定的闹钟提醒时间"时,计数单元就会向中断系统发出中断申请,产生"闹钟提醒",使程序跳到中断服务函数中执行。

 定时器工作模式:

  • STC89C52的T0和T1均有四种工作模式:

        模式0:13位定时器/计数器

        模式1:16位定时器/计数器(常用)

        模式2:8位自动重装模式

        模式3:两个8位计数器

        定时器/计数器除模式3外,其他工作模式与定时器/计数器0相同,T1在模式3时无效,停止计数。

  • 下面以模式1(16位定时器/计数器)为例:

一、时钟

  • SYSclk:系统时钟(System Clock),即晶振周期,单片机核心工作频率,决定指令执行速度。本开发板上晶振为11.0592MHz。
  • ÷12/÷6:分频器

        12T模式:每12个时钟周期构成1个机器周期(速度较慢,兼容传统设计)。

        6T模式:每6个时钟周期构成1个机器周期(速度更快,适合高性能场景)。

  •  C/\frac{}{T}:模式选择位(Counter/Timer Select Bit)

         C/\frac{}{T}=0:定时器模式,对分频后的系统时钟脉冲计数(用于计时)。

        C/\frac{}{T}=1:计数器模式,对T0 Pin(外部引脚)的脉冲信号计数(用于统计外部事件)。

二、计数单元

  • TR0:定时器0运行控制位(Timer 0 Run Control)。 

        TR0=1:启动定时器/计数器;TR0=0:停止。

  • GATE:门控位。

        GATE=1:定时器启动需要满足TR0=1 且\frac{}{INT0}=1(外部中断0引脚高电平)。

        GATE=0:仅需TR0=1即可启动。 

  • \frac{}{INT0}:外部中断0引脚,用于门控模式下协同控制。
  • 16位寄存器:

        TL0(8 Bits):低8位计数器,存储计数值低字节。

        TH0(8 Bits):高8位计数器,存储计数值高字节。

 三、中断

  • TF0:定时器0溢出标志(Timer 0 Overflow Flag)

        当计数器从65535加1变为0时,TF0自动置1,触发中断请求。

  • Interrupt:中断信号,通知CPU处理定时器溢出事件(例如更新显示、执行任务)。 

2.中断系统 

当中央处理机CPU正在处理某件事的时候外界发生了紧急事件请求,要求CPU暂停当前
的工作,转而去处理这个紧急事件,处理完以后,再回到原来被中断的地方,继续原来的工
作,这样的过程称为中断。实现这种功能的部件称为中断系统,请示CPU中断的请求源称为
断源

举个煮面例子说明:

关键对应关系: 

厨房场景中断系统电路图对应(TF0中断)
煮面流程主程序执行定时器正常计数 (TL0/TH0累加)
电话响铃中断源触发定时器溢出导致TF0=1,触发中断
关火并记住进度保存CPU现场硬件自动保存程序计数器(PC)
接电话执行中断服务程序跳转到中断向量表执行定时器中断代码
重新开火继续煮面恢复现场并继续主程序

RETI指令返回,恢复PC继续主流程

下图以STC89C51RC/RD+系列讲解中断系统结构示意图:

 

一、中断源与触发机制

图中左侧标注了 8个中断源,按触发类型分为三类:

  • 外部中断(4个)

        INT0(外部中断0):

         触发方式:由 TCON.0/IT0 位设置(0=低电平触发,1=下降沿触发)。

         标志位:IE0(TCON.1),触发后自动置1。

        INT1/INT2/INT3(外部中断1/2/3):类似INT0,分别由 TCON.2/IT1XICON.0/IT2XICON.2/IT3 控制触发方式,标志位为 IE1/IE2/IE3

  • 定时器中断(3个)

        Timer0/TF0:定时器0溢出时 TF0(TCON.5)置1,允许位 ET0(IE.1)。

        Timer1/TF1:定时器1溢出时 TF1(TCON.7)置1,允许位 ET1(IE.3)。

        Timer2/TF2/EXF2:溢出触发 TF2(T2CON.7),外部触发 EXF2(T2CON.6),允许位 ET2(IE.5)。

  • 串口中断(UART)

        接收中断:RI(SCON.0)置1时触发。

        发送中断:TI(SCON.1)置1时触发。

        统一允许位 ES(IE.4)。

二、中断允许控制寄存器

  • IE寄存器(Interrupt Enable)

        全局控制:EA=1(IE.7)时总中断允许生效。

        分项控制:

   EX0=1(IE.0):允许外部中断0

    ET0=1(IE.1):允许定时器0中断

    EX1=1(IE.2):允许外部中断1

    ET1=1(IE.3):允许定时器1中断

    ES=1(IE.4):允许串口中断

    ET2=1(IE.5):允许定时器2中断

  • XICON寄存器(扩展中断控制)

        扩展允许位:EX2=1(XICON.4)、EX3=1(XICON.5)分别允许外部中断2/3。

        触发方式:IT2(XICON.0)、IT3(XICON.2)设置边沿/电平触发。

 三、中断优先级控制

  • IP/IPH寄存器(Interrupt Priority)

        标准优先级(IP):每个中断源对应1位(0=低优先级,1=高优先级)。

          例如:PX0=1(IP.0)设置外部中断0为高优先级。

        扩展优先级(IPH):与IP组合实现 4级优先级(STC特有功能):

   PX0H:PX0(IPH.0:IP.0)= 00(0级)→11(3级),数值越大优先级越高。

  • 中断查询次序,图中右侧竖列标注了中断响应顺序(优先级相同时的默认查询次序):

        INT0->Timer0->INT1->Timer1->UART->Timer2(优先级 高->低)

3.配置定时器和中断示例

#include <REGX52.H>/*** @brief  定时器0初始化,1毫秒@11.0592MHZ* @param 	无* @retval 无*/
void Timer0Init(void)		//1毫秒@11.0592MHz
{TMOD &= 0xF0;		//清零低4位(对应定时器0的配置),保留高4位(定时器1的配置)不变TMOD |= 0x01;		//设置定时器0为模式1(二进制0000 0001中的低4位),即16位定时器模式TL0 = 0x66;		//设置定时初值TH0 = 0xFC;		//设置定时初值TF0 = 0;		//清除定时器0溢出标志位,防止初始化后立即触发中断TR0 = 1;		//启动定时器0,开始计数ET0=1;			//开启定时器0中断(ET0)和全局中断(EA),允许中断触发			EA=1;PT0=0;			//设置定时器0中断优先级为低优先级
}//定时器通用模板
//void Timer0_Routine() interrupt 1{
//	static unsigned int T0Count;
//	TL0 = 0x66;		//设置定时初值
//	TH0 = 0xFC;		//设置定时初值
//	T0Count++;
//	if(T0Count>=1000)
//	{
//		T0Count=0;
//	}
//}

相关文章:

51单片机使用定时器实现LCD1602的时间显示(STC89C52RC)

本文前半部分直接给出实现&#xff08;注意进位问题是秒->分->小时&#xff0c;用 if 嵌套即可实现&#xff09;&#xff0c;后半部分讲解定时器和中断系统。 效果展示&#xff1a; LCD1602电路图&#xff1a; 项目结构&#xff1a; 代码实现&#xff1a; main.c #…...

微软2025年AI技术深度解析:从多模态大模型到企业级代理服务

微软2025年AI技术深度解析&#xff1a;从多模态大模型到企业级代理服务 一、微软AI技术全景概览 在2025年的AI领域&#xff0c;微软通过Azure AI Foundry、多模态大模型、企业级AI代理三大核心技术&#xff0c;构建了覆盖开发、部署、应用全流程的AI生态体系。根据最新财报数…...

24 设计模式总结

设计模式分类&#xff08;意图&#xff09; • 创建型模式&#xff1a;创建对象的机制&#xff0c;从所需要实例化的对象中解耦。 • 结构型模式&#xff1a;将对象或类组装到更大的结构中。 • 行为型模式&#xff1a;负责对象间的交互和分配职责。分类的目的是为了更抽象的了…...

【ARTS】2873.有序三元组中的最大值!

前言 仅做学习使用&#xff0c;侵删 什么是ARTS&#xff1f; 算法(Algorithm): 每周至少一道LeetCode算法题&#xff0c;加强编程训练和算法学习 阅读(Review)&#xff1a; 阅读并点评至少一篇英文技术文章&#xff0c;提高英文水平 技巧 (Tip)&#xff1a;学习至少一个技…...

Mysql进阶

目录 一.Mysql架构 1.连接层 2.服务层 3.引擎层 4.物理文件存储层 二.Mysql引擎 1.InnoDB 2.MyISAM 三.索引 1.什么是索引 2.为什么要有索引 3.索引的原理 4.索引优势 5.索引劣势 6.索引分类 主键索引 唯一索引 单值索引 组合索引&#xff08;复合索引&#…...

探秘JVM内部

在我们编写Java代码&#xff0c;点击运行后&#xff0c;会发生什么事呢&#xff1f; 首先&#xff0c;Java源代码会经过Java编译器将其编译成字节码&#xff0c;放在.class文件中 然后这些字节码文件就会被加载到jvm中&#xff0c;然后jvm会读取这些文件&#xff0c;调用相关…...

c语言学习12天

c语言的宏定义&#xff1a;宏定义单纯的文本替换不会检查语法是否合法 #include #pragma 以及开头的#都属于预处理指令 预处理指令&#xff1a;在gcc编译套件中的cpp预处理器对程序进行编译之前所做的一些动作&#xff0c;如#include预处理指令就是在程序编译之前有预处理器…...

公司内网部署离线deepseek本地模型实战

企业内部可能有些数据比较敏感&#xff0c;不能连接互联网。deepseek来提高工作效率&#xff0c;这个时候你可以利用ollama在内网本地部署来实现。 本式样是先在自己电脑上用虚拟机部署好&#xff0c;再用U盘把虚拟机文件复制到内网去。 一、使用VMware新建WIN2022虚拟机 &a…...

rocketmq中的延迟队列使用详解

RocketMQ的延迟队列通过预设的延迟等级实现消息的定时投递&#xff0c;适用于订单超时、定时通知等高并发场景。以下是其核心原理、使用方式及优化策略的详细解析&#xff1a; 一、实现原理 延迟等级机制 RocketMQ默认提供18个固定延迟等级&#xff08;1s、5s、10s、30s、1m、2…...

VB.NET Asp.Net Core模板WebAPI应用-宝塔面板Linux系统通过Docker部署

宝塔面板支持在Linux系统上部署Docker容器吗&#xff1f; 如何在宝塔面板上通过Docker部署VB.NET应用&#xff1f; Docker容器中的VB.NET Asp.Net Core WebAPI应用如何配置&#xff1f; 一,首先,创建一个ASP.NET Core测试项目 1.1 打开VS2019/2022,创建一个.NTE6 Core控制台应…...

4985 蜗牛

4985 蜗牛 ⭐️难度&#xff1a;中等 ⭐️考点&#xff1a;2023、省赛、动态规划 &#x1f4d6; &#x1f4da; import java.util.Scanner; // 1:无需package // 2: 类名必须Main, 不可修改public class Main {public static void main(String[] args) {Scanner sc new Sc…...

springboot多模块工程打包部署运行

1、问题概述? 基于实际项目打包过程,各种配置面面俱到,已配置的可跳过。 本文以打包jar包为模板进行操作,部署方便。 在实际的开发中,项目的模块可能较多,如果都放在一个项目的目录中,势必会造成项目包中的文件冗余,难以管理,这个时候就需要使用多模块管理项目。 …...

吴恩达深度学习复盘(8)神经网络中激活函数的建模

激活函数的建模原理 到目前为止&#xff0c;在隐藏层等一直使用激活函数&#xff0c;最初通过逻辑回归建立新网络&#xff0c;组合多个逻辑回归单元。这表明激活函数在神经网络构建中一直存在&#xff0c;且最初的网络构建方式与逻辑回归相关。实际上&#xff0c;激活函数的种类…...

1-linux的基础知识

一.linux的文件系统结构 windows文件系统 微软windows系统将硬盘上的几个分区&#xff0c;用A: B: C: D:等符号标识。存取文件时一定要清楚放在那个磁盘的那个目录下。 linux文件系统 linux文件系统的组织模式犹如一颗倒置的树&#xff0c;这与windows文件系统有很大的差别…...

docker 常用命令

文章目录 一、帮助启动类命令启动docker停止docker重启docker查看docker状态开机自启查看docker概要信息 二、镜像命令列出本地主机上的镜像搜索镜像拉取镜像查看镜像所占空间删除镜像 三、容器命令新建运行容器交互式启动容器守护进程式启动容器列出当前所有的容器进入容器之后…...

使用docker搭建redis镜像时云服务器无法访问到国外的docker官网时如何解决

下载redis镜像 docker redis:版本号 此时截图中无法访问到国外的docker官网 解决方案&#xff1a; 通过更换镜像源来正常下载redis镜像 sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json <<EOF {"registry-mirrors": ["https://docker.1…...

基于Python的人脸识别校园考勤系统

【Python】基于Python的人脸识别校园考勤系统 &#xff08;完整系统源码开发笔记详细部署教程&#xff09;✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 &#x1f31f; 该系统主要分为前端和后端两个部分&#xff0c;前端&#x1f440;负责人脸采集、人…...

微信小程序学习实录11:startLocationUpdateBackground:fail auth deny

startLocationUpdateBackground:fail auth deny 表明小程序在尝试开启后台位置更新时&#xff0c;用户授权被拒绝。以下是可能的原因及解决方法&#xff1a; 原因分析 缺少必要的用户授权&#xff1a; 使用 wx.startLocationUpdateBackground 接口需要用户授予 scope.userLo…...

DAPP实战篇:规划下我们的开发线路

前言 在DApp实战篇&#xff1a;先用前端起个项目一文中我们起了一个前端项目&#xff0c;在后续开发中笔者将带领大家一步步完成这个DAPP&#xff0c;为了方便后续讲解&#xff0c;本篇将完整说明后续我们要进行的开发和思路。 主打前端 实际上一个完整的DAPP是由前端和智能…...

docker配置redis容器时配置文件docker-compose.yml示例

1.配置数据节点&#xff08;主从节点&#xff09; version: 3.7 services:master:image: redis:5.0.9container_name: redis-masterrestart: alwayscommand: redis-server --appendonly yesports:- 6379:6379slave1:image: redis:5.0.9container_name: redis-slave1restart: a…...

清晰易懂的 Jenkins 安装与核心使用教程

Jenkins 是业界领先的开源自动化服务器&#xff0c;用于实现持续集成与持续交付&#xff08;CI/CD&#xff09;。本教程将覆盖 安装部署、核心功能配置、避坑指南&#xff0c;助你快速掌握企业级自动化流水线搭建&#xff01; 一、Jenkins 安装&#xff08;全平台指南&#xff…...

anomalib—2—输入图像大小调整

三个地方 第一&#xff1a;在定义model时&#xff0c;要在pre_processor里面去定义一个前处理&#xff0c;前处理就一个功能&#xff0c;定义图像的大小 pre_processor0 Patchcore.configure_pre_processor( image_size (128, 128)) model Patchcore( backbone"wide_r…...

小型园区组网图

1. 在小型园区中&#xff0c;S5735-L-V2通常部署在网络的接入层&#xff0c;S8700-4通常部署在网络的核心&#xff0c;出口路由器一般选用AR系列路由器。 2. 接入交换机与核心交换机通过Eth-Trunk组网保证可靠性。 3. 每个部门业务划分到一个VLAN中&#xff0c;部门间的业务在C…...

编程哲学——TCP可靠传输

TCP TCP可靠传输 TCP的可靠传输表现在 &#xff08;1&#xff09;建立连接时三次握手&#xff0c;四次挥手 有点像是这样对话&#xff1a; ”我们开始对话吧“ ”收到“ ”好的&#xff0c;我收到你收到了“ &#xff08;2&#xff09;数据传输时ACK应答和超时重传 ”我们去吃…...

2024华为OD机试真题-任务最优调度(C++/Java/Python)-E卷-200分

2024华为OD机试最新E卷题库-(D卷+E卷)-(JAVA、Python、C++) 目录 题目描述 输入描述 输出描述 用例1 考点 题目解析 代码 c++ java python 题目描述 给定一个正整数数组表示待系统执行的任务列表,数组的每一个元素代表一个任务,元素的值表示该任务的类型。请计算执…...

蓝桥杯 2023省B 飞机降落 dfs

传送门 P9241 [蓝桥杯 2023 省 B] 飞机降落 - 洛谷 n<10&#xff0c;考虑dfs&#xff0c;只有当 当前飞机的到达时刻盘旋时间 < 上一个飞机降落的时刻 时&#xff0c;当前飞机才能降落 const int N 1e3 10;int n; struct Node {LL t,d,l; }a[N];bool st[N];bool dfs(in…...

Mybatis--动态SQL

动态SQL是MyBatis的重要特征之一&#xff0c;能够完成不同条件下的SQL拼接&#xff0c;参考文档&#xff1a;动态 SQL_MyBatis中文网 一、<if>标签 该标签主要适用的情况为实现必填字段和非必填字段&#xff1a; 例如下面的例子就是将用户表中的性别设置成了非必填字段…...

计算机视觉中的基于网格的卷绕算法全解析

大家好呀&#xff5e;今天给大家带来一个超级实用且有趣的计算机视觉技巧&#xff1a;基于网格的卷绕算法&#xff08;Grid Warp Algorithm&#xff09;&#xff01;如果你对图像变形、动画制作感兴趣&#xff0c;那一定不要错过这篇文章哦&#xff01;话不多说&#xff0c;直接…...

xv6 文件系统

Buffer Cache buffer Cache 结构体 bcache 存放了 NBUF 个 buf 框&#xff0c;每个框对应 disk 上某一个 block。从初始化函数 binit中可以看出&#xff0c;bcache 是一个循环双向链表。通过双链表组织这些 buf&#xff0c;以近似 LRU 的策略管理&#xff0c;大概如下图。 st…...

Python Cookbook-5.5 根据内嵌的数字将字符串排序

任务 你想将一个字符串列表进行排序&#xff0c;这些字符串都含有数字的子串(比如一系列邮寄地址)。举个例子&#xff0c;“foo2.txt”应该出现在“foo10.txt”之前。然而&#xff0c;Python 默认的字符串比较是基于字母顺序的&#xff0c;所以默认情况下&#xff0c;“foo10.…...

EMC内参二(1-45页)学习【技术进阶】

EMC设计介入产品设计时间越早&#xff0c;成本越低。 微带线和带状线的区别&#xff1a; 微带线是PCB外层的走线&#xff0c;带状线是结余两个完整参考平面&#xff08;电源层和地层&#xff09;之间的走线。 天线效应&#xff1a; PCB上面任何悬空的金属都会积累电荷&…...

Ansible(7)——管理机密

目录 一、Ansible Vault &#xff1a; 二、ansible-vault 命令行工具&#xff1a; 1、创建加密文件&#xff1a; 2、查看加密文件&#xff1a; 3、编辑现有加密文件&#xff1a; 4、加密现有文件&#xff1a; 5、解密现有文件&#xff1a; 6、更改加密文件的密码&#…...

通俗地讲述DDD的设计

通俗地讲述DDD的设计 前言为什么要使用DDDDDD架构分层重构实践关键问题解决方案通过​​领域事件机制​​解耦服务依赖&#xff1a;防止逻辑下沉 领域划分电商场景下的领域划分 结语完结撒花&#xff0c;如有需要收藏的看官&#xff0c;顺便也用发财的小手点点赞哈&#xff0c;…...

【学Rust写CAD】34 精确 Alpha 混合函数(argb.rs补充方法)

源码 #[inline]pub fn over_exact(self, dst: Argb) -> Argb {let a 255 - self.alpha32();let t dst.rb() * a 0x80_00_80;let mut rb (t ((t >> 8) & Argb::MASK)) >> 8;rb & Argb::MASK;rb self.rb();// saturaterb | 0x1000100 - ((rb >&…...

10种电阻综合对比——《器件手册--电阻》

二、电阻 前言 10种电阻对比数据表 电阻类型 原理 特点 应用 贴片电阻 贴片电阻是表面贴装元件&#xff0c;通过将电阻体直接贴在电路板上实现电路连接 体积小、重量轻&#xff0c;适合高密度电路板&#xff1b;精度高、稳定性好&#xff0c;便于自动化生产 广泛应用于…...

SpringCloud入门及创建分布式项目

1、了解微服务 1.1 什么是微服务 微服务是一种架构风格一个应用拆分为一组小型服务每个服务运行在自己的进程内&#xff0c;也就是可独立部署和升级服务之间使用轻量级HTTP交互服务围绕业务功能拆分可以由全自动部署机制独立部署去中心化&#xff0c;服务自治。服务可以使用不同…...

xv6启动过程

entry,S -> start.c -> main.c -> proc.c中的 userinit 函数 -> initcode.S -> init.c entry.S // entry.S# qemu -kernel loads the kernel at 0x80000000# and causes each CPU to jump there.# kernel.ld causes the following code to# be placed at 0x800…...

【秣厉科技】LabVIEW工具包——OpenCV 教程(18):highgui 模块

文章目录 前言highgui 模块总结 前言 需要下载安装OpenCV工具包的朋友&#xff0c;请前往 此处 &#xff1b;系统要求&#xff1a;Windows系统&#xff0c;LabVIEW>2018&#xff0c;兼容32位和64位。 highgui 模块 尽量别用&#xff0c;要不我删了吧&#xff1f; LabVIEW…...

基于OPENCV的图像透视矫正

这段代码的主要功能是对输入的图像进行透视矫正。它会读取一张图像&#xff0c;检测图像中最大的四边形轮廓&#xff0c;然后对该四边形区域进行透视变换&#xff0c;将其矫正为正视图&#xff0c;最后保存矫正后的图像。 模块导入说明 python import cv2 import numpy as n…...

数据结构----------顺序查找,折半查找和分块查找(java实现)

import java.util.Arrays;//顺序查找法 public class Main {public static void main(String[] args) {//查找表int[] arr {4, 3, 5, 1, 2};System.out.print("5在数组中的索引:");System.out.println(SearchSeq(arr, 5));Arrays.sort(arr);System.out.print("…...

整数编码 - 华为OD统一考试(A卷、JavaScript)

题目描述 实现一种整数编码方法&#xff0c;使得待编码的数字越小&#xff0c;编码后所占用的字节数越小。 编码规则如下: 编码时7位一组&#xff0c;每个字节的低7位用于存储待编码数字的补码。字节的最高位表示后续是否还有字节&#xff0c;置1表示后面还有更多的字节&…...

CompletableFuture:整合、超时、完成事件与批量处理

引言 在异步编程实践中&#xff0c;我们不仅需要处理单个任务的执行流程&#xff0c;更需要应对多个异步任务之间的复杂交互。本文将通过实际案例解析以下核心功能&#xff1a; 双任务整合&#xff1a;合并两个独立任务的结果高效超时控制&#xff1a;防止异步操作无限等待完…...

【LeetCode 热题100】45:跳跃游戏 II(详细解析)(Go语言版)

&#x1f680; 力扣 45&#xff1a;跳跃游戏 II&#xff08;全解法详解&#xff09; &#x1f4cc; 题目描述 给你一个非负整数数组 nums&#xff0c;表示你最初位于数组的第一个位置。 数组中的每个元素表示你在该位置可以跳跃的最大长度。 你的目标是使用 最少的跳跃次数 到…...

【C/C++】滑动谜题(leetcode T773)

核心考点&#xff1a;广度优先搜索 (BFS)、哈希表、字符串、状态转移 题目描述&#xff1a; 在一个 2 x 3 的板上&#xff08;board&#xff09;有 5 块砖瓦&#xff0c;用数字 1~5 来表示, 以及一块空缺用 0 来表示。一次 移动 定义为选择 0 与一个相邻的数字&#xff08;上…...

python用x08覆盖上一次输出来模拟控制台等待效果,pycharm运行sys.stdout.write在控制台无打印的解决方法

一个多进程程序&#xff0c;主进程阻塞&#xff0c;子进程不断打印等待效果直到主进程结束&#xff0c;原理是\x08在ascii中表示退格键&#xff0c;理解为打印完后立马删掉打印下一个内容。 import sys, time import multiprocessing DELAY 0.1 DISPLAY [ |, /, -, \\ …...

【嵌入式开发】使用Linux系统调用编程练习

一、进程和线程的概念及基础用法 在Linux系统中&#xff0c;进程&#xff08;Process&#xff09;和线程&#xff08;Thread&#xff09;是操作系统进行任务调度的基本单位&#xff0c;它们既有联系又有区别。 1.1 进程和线程介绍 1.1.1 进程&#xff08;Process&#xff09…...

React框架的Concurrent Mode

以下是关于 Concurrent Mode 的系统梳理: 一、Concurrent Mode 的诞生背景 传统渲染的局限性 同步阻塞:React 15 的 Stack Reconciler 无法中断渲染流程优先级缺失:用户交互与后台任务同等对待资源竞争:网络请求与渲染任务无法智能调度核心设计目标 可中断渲染:允许高优先…...

ER-图,详情和画法

一、E-R图的核心元素 1.实体 表示现实中对象或概念&#xff0c;用矩形表示 示例&#xff1a;用户、老师、学生 2.属性 描述实体的特征&#xff0c;用椭圆表示。 分为主键&#xff08;用户id&#xff09; 和非主键&#xff08;用户昵称&#xff09; 3.关系 表示实体间的…...

深度学习图像分类数据集—十种西红柿病态叶识别分类

该数据集为图像分类数据集&#xff0c;适用于ResNet、VGG等卷积神经网络&#xff0c;SENet、CBAM等注意力机制相关算法&#xff0c;Vision Transformer等Transformer相关算法。 数据集信息介绍&#xff1a;10种西红柿病态叶识别分类&#xff1a;Bacterial_spot&#xff0c;Earl…...

【Flask开发】嘿马文学web完整flask项目第3篇:2.用户认证,2.用户认证【附代码文档】

教程总体简介&#xff1a;2. 目标 1.1产品与开发 1.2环境配置 1.3 运行方式 1.4目录说明 1.5数据库设计 2.用户认证 Json Web Token(JWT) 3.书架 4.1分类列表 5.搜索 5.3搜索-精准&高匹配&推荐 6.小说 6.4推荐-同类热门推荐 7.浏览记录 8.1配置-阅读偏好 8.配置 9.1项目…...