【STM32嵌入式系统设计与开发】——9Timer(定时器中断实验)

这里写目录标题

  • 一、任务描述
  • 二、任务实施
    • 1、ActiveBeep工程文件夹创建
    • 2、函数编辑
      • (1)主函数编辑
      • (2)USART1初始化函数(usart1_init())
      • (3)USART数据发送函数( USART1_Send_Data())
      • (4)USART数据发送函数( USART1_IRQHandler())
      • (5)系统时间初始化函数( SystemTinerInit())
      • (6)等待计时函数( WaitTimerOut())
      • (7)系统时间定时器中断服务函数( TIM3_IRQHandler())
      • (8)获取系统计时时间函数( GetSystemTimer())
    • 3、宏定义
      • 定时器宏定义
    • 4、知识链接
      • (1)不同类型的定时器模块
      • (2)计数器模式
      • (3)STM32中断
    • 5、工程测试


STM32资料包:
百度网盘下载链接:链接:https://pan.baidu.com/s/1mWx9Asaipk-2z9HY17wYXQ?pwd=8888
提取码:8888


一、任务描述

请添加图片描述

二、任务实施

观察电路图:
TXD(底板) ————————> PA10
RXD(底板) ————————> PA9
使用USB-AB型数据线,连接15核心板USB口,串口发送接收到的数据。在这里插入图片描述

1、ActiveBeep工程文件夹创建

步骤1:复制工程模板“1_Template”重命名为“7_Timer”。
在这里插入图片描述
步骤2:修改项目工程名,先删除projects文件夹内除了Template.uvprojx文件外的所有内容并修改为“Timer.uvprojx”。并删除output/obj和output/lst中的所有文件。
在这里插入图片描述
步骤3:运行“Timer.uvprojx”打开目标选项“Options for Target”中的“Output”输出文件,并修改可执行文件名称为“Usart”点击“OK”保存设置。最后点击“Rebuild”编译该工程生成Usart文件。
请添加图片描述
步骤4:复制“2_LEDTest”中的"1_LED"文件复制到hardware中。
在这里插入图片描述
步骤6:工程组文件中添加“led.c”和“ActiveBeep.c”文件。
请添加图片描述
步骤7:目标选项添加添加头文件路径。
在这里插入图片描述

2、函数编辑

(1)主函数编辑

连接15核心板USB口,串口发送接收到的数据,串口助手发送一段数据帧,判断数据帧后返回相应数据。
在这里插入图片描述
步骤1:端口初始化准备

    //定义变量uint32_t temp=0,t = 0, x = 0,r = 0;//函数初始化,端口准备delay_init();                       //启动滴答定时器usart1_init(9600);                  //USART1初始化SystemTinerInit(1000-1,7200-1);     //系统时间初始化 定时100ms

在这里插入图片描述

步骤2:实现一个简单的计时器,并在每秒打印一次计时信息。利用LED状态的改变来指示系统正在运行。

printf("初始化成功!\r\n");
while(1)
{/* 如果定时器超时5秒,交替翻转LED状态 */if(WaitTimerOut(5))LED = !LED;/* 获取系统时间并检查是否刚好过了1秒 */temp = GetSystemTimer() % 10;if((temp == 0) && (!t)) {t = 1;r = 1;}/* 如果不到1秒,将t重置为0 */if(temp != 0)t = 0;/* 如果r为真,则打印一次 */if(r) {x += 1;r = 0;printf("计时第 %d 秒!\r\n", x);}
}

在这里插入图片描述

(2)USART1初始化函数(usart1_init())

配置了 PA9 为复用推挽输出,用于 USART1 的 TXD,并配置了 PA10 为浮空输入,用于 USART1 的 RXD。并配置了 USART1 的参数,包括波特率、数据位长度、停止位数、校验位、硬件流控制和工作模式。

/*********************************************************************@Function  : USART1初始化@Parameter : bound : 波特率 @Return    : N/A
**********************************************************************/   	
void usart1_init(uint32_t bound)
{GPIO_InitTypeDef GPIO_InitStructure;             										          // 定义 GPIO 初始化结构体USART_InitTypeDef USART_InitStructure;            										          // 定义 USART 初始化结构体NVIC_InitTypeDef NVIC_InitStructure;              										          // 定义 NVIC 初始化结构体/* 时钟使能:启用 USART1 和 GPIOA 的时钟 */RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA, ENABLE);/* 引脚复用配置 */  // 配置 PA9 为复用推挽输出,用于 USART1 的 TXDGPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;   		                             // 设置 GPIO 端口GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;                                // 设置 GPIO 速度GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; 								 // 设置 GPIO 模式为复用推挽GPIO_Init(GPIOA, &GPIO_InitStructure);          							     // 初始化 GPIO// 配置 PA10 为浮空输入,用于 USART1 的 RXDGPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;                                      // 设置 GPIO 端口GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;                           // 设置 GPIO 模式为浮空输入GPIO_Init(GPIOA, &GPIO_InitStructure);                                          // 初始化 GPIO/* NVIC 中断配置 */ NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;                               // 设置中断通道为 USART1NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3;                       // 设置抢占优先级为3NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;                              // 设置子优先级为3NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                                 // 使能中断通道NVIC_Init(&NVIC_InitStructure);                                                 // 初始化 NVIC/* USART1 配置 */ USART_InitStructure.USART_BaudRate = bound;                                     // 设置波特率USART_InitStructure.USART_WordLength = USART_WordLength_8b;                     // 设置数据位长度为8位USART_InitStructure.USART_StopBits = USART_StopBits_1;                          // 设置停止位为1位USART_InitStructure.USART_Parity = USART_Parity_No;                             // 设置校验位为无校验USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; // 设置硬件流控制为无USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;                 // 设置工作模式为接收和发送USART_Init(USART1, &USART_InitStructure);                                       // 初始化 USART1/*中断配置*/USART_ITConfig(USART1,USART_IT_RXNE,ENABLE);                                //开接受中断 USART_ITConfig(USART1,USART_IT_IDLE,ENABLE);                                //开空闲中断USART_ITConfig(USART1,USART_IT_TXE,ENABLE);                                 //开发送中断	USART_Cmd(USART1, ENABLE);                                                  //启用USART1USART_DataTypeStr.Usart_Tc_State = SET;	                                    //置位发送允许标志	      
}

在这里插入图片描述

(3)USART数据发送函数( USART1_Send_Data())

初始化PD14端口,并为推挽输出。

/*********************************************************************@Function  : USART数据发送函数@Parameter : Data 	 :要发送的数据缓存.Lenth  :发送长度@Return    : 发送状态   1 :失败   0 :成功
**********************************************************************/
char USART1_Send_Data(char* Data,uint8_t Lenth) 
{uint8_t uNum = 0;if(USART_DataTypeStr.Usart_Tc_State == 1)                       //判断发送标志位是否置1{USART_DataTypeStr.Usart_Tc_State = 0;                       //将发送标志位清零,表示数据已经成功放入缓存,等待发送USART_DataTypeStr.Usart_Tx_Len = Lenth;                     //获取需要发送的数据的长度       for(uNum = 0;uNum < USART_DataTypeStr.Usart_Tx_Len;uNum ++)   //将需要发送的数据放入发送缓存{USART_DataTypeStr.Usart_Tx_Buffer[uNum] = Data[uNum];}USART_ITConfig(USART1,USART_IT_TXE,ENABLE);			            //数据放入缓存后打开发送中断,数据自动发送}return USART_DataTypeStr.Usart_Tc_State;                        //返回放数据的状态值,为1表示发送失败,为0表示发送成功了
}

在这里插入图片描述

(4)USART数据发送函数( USART1_IRQHandler())

/*********************************************************************@Function  : USART1中断服务函数@Parameter : N/A @Return    : N/A
**********************************************************************/
void USART1_IRQHandler(void)                
{uint8_t Clear = Clear;                                                                           // 定义清除标志的变量,并初始化为自身static uint8_t uNum = 0;                                                                          // 静态变量,用于循环计数if(USART_GetITStatus(USART1,USART_IT_RXNE) != RESET)                                                // 判断读数据寄存器是否为非空{USART_ClearFlag(USART1, USART_IT_RXNE);                                                           // 清零读数据寄存器,其实硬件也可以自动清零USART_DataTypeStr.Usart_Rx_Buffer[USART_DataTypeStr.Usart_Rx_Num ++] = \(uint16_t)(USART1->DR & 0x01FF);                                                              // 将接收到的数据存入接收缓冲区(USART_DataTypeStr.Usart_Rx_Num) &= 0xFF;                                                     // 防止缓冲区溢出} else if(USART_GetITStatus(USART1,USART_IT_IDLE) != RESET)   // 检测空闲{Clear = USART1 -> SR;                                                                         // 读SR位Clear = USART1 -> DR;                                                                       // 读DR位,USART_DataTypeStr.Usart_Rx_Len = USART_DataTypeStr.Usart_Rx_Num;                              // 获取数据长度for(uNum = 0; uNum < USART_DataTypeStr.Usart_Rx_Len; uNum ++)          {USART_DataTypeStr.Usart_Rx_Data[uNum] = USART_DataTypeStr.Usart_Rx_Buffer[uNum];      // 将接收到的数据复制到接收数据缓冲区}USART_DataTypeStr.Usart_Rx_Num = 0;                                                           // 清空接收计数器USART_DataTypeStr.Usart_Rc_State = 1;                                                         // 数据读取标志位置1,读取串口数据}if(USART_GetITStatus(USART1,USART_IT_TXE) != RESET)                                                  // 判断发送寄存器是否为非空{USART1->DR = \((USART_DataTypeStr.Usart_Tx_Buffer[USART_DataTypeStr.Usart_Tx_Num ++]) & (uint16_t)0x01FF);    // 发送数据(USART_DataTypeStr.Usart_Tx_Num) &= 0xFF;                                                       // 防止缓冲区溢出if(USART_DataTypeStr.Usart_Tx_Num >= USART_DataTypeStr.Usart_Tx_Len){   USART_ITConfig(USART1,USART_IT_TXE,DISABLE);                                                // 发送完数据,关闭发送中断USART_DataTypeStr.Usart_Tx_Num = 0;                                                         // 清空发送计数器USART_DataTypeStr.Usart_Tc_State = 1;                                                       // 发送标志置1,可以继续发送数据了} 		}}

在这里插入图片描述

(5)系统时间初始化函数( SystemTinerInit())

Tout=((arr+1)*(psc+1))/Ft us,Ft=定时器工作频率,单位:Mhz;初始化TIM3定时器,配置定时器的周期值、预分频值、计数模式等参数,并使能定时器及其中断

/*********************************************************************@Function  : 系统时间初始化@Parameter : arr:自动重装值。psc:时钟预分频数@Return    : N/A@Read 			:Tout=((arr+1)*(psc+1))/Ft us,Ft=定时器工作频率,单位:Mhz
**********************************************************************/
void SystemTinerInit(uint16_t arr, uint16_t psc)
{TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;               // 定义TIM基本参数结构体NVIC_InitTypeDef NVIC_InitStructure;                         // 定义中断优先级配置结构体/* 时钟使能 */RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, ENABLE);         // 使能TIM3时钟/* TIM配置 */TIM_TimeBaseStructure.TIM_Period = arr;                      // 设置定时器的周期值TIM_TimeBaseStructure.TIM_Prescaler = psc;                   // 设置定时器的预分频值TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;      // 设置时钟分频因子为1TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  // 设置计数模式为向上计数TIM_TimeBaseInit(TIM3, &TIM_TimeBaseStructure);              // 初始化TIM3定时器/* 允许中断 */TIM_ITConfig(TIM3, TIM_IT_Update, ENABLE);                   // 使能TIM3更新(溢出)中断/* NVIC 配置 */NVIC_InitStructure.NVIC_IRQChannel = TIM3_IRQn;              // 设置TIM3中断通道NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;    // 设置TIM3中断的抢占优先级为0NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;           // 设置TIM3中断的子优先级为3NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;              // 使能TIM3中断通道NVIC_Init(&NVIC_InitStructure);                              // 初始化NVIC/* 使能TIMx */TIM_Cmd(TIM3, ENABLE);                                       // 使能TIM3定时器
}

(6)等待计时函数( WaitTimerOut())

定时器超时检测功能,根据传入的参数 gTimer 和系统时钟计数器,判断定时器是否超时,并返回相应的状态。

/*********************************************************************@Function  : 等待计时@Parameter : gTimer :等待时间,100ms一个单位@Return    : 1表示超时,0表示未超时
**********************************************************************/
uint8_t WaitTimerOut(uint32_t gTimer)
{	uint32_t GTr = 0;                         // 定义变量用于存储定时器剩余时间if(gTimer==0) return 1;                   // 如果等待时间为0,则直接返回1,表示不等待GTr = SystemTimer % gTimer;	              // 计算定时器剩余时间if((GTr==0) && (!Rti) && (Gti != gTimer)) // 如果定时器剩余时间为0,且上次未检测到超时,并且当前定时器时间不等于上次记录的时间{ Rti=1;                                // 设置标志表示检测到定时器超时Gti = gTimer;                         // 更新记录的定时器时间return 1;                             // 返回1表示超时}else if((GTr!=0) && (Rti))                // 如果定时器剩余时间不为0,且上次检测到超时,则将标志置为0Rti=0;if(!GetTimer) GetTimer = SystemTimer;	  // 如果记录定时器开始时间为0,则将其设置为当前系统时间if(SystemTimer - GetTimer == gTimer)      // 如果当前系统时间减去记录的定时器开始时间等于设定的等待时间,则返回1表示超时{ GetTimer = 0;                         // 将记录的定时器开始时间清零,准备下一次记录return 1;                             // 返回1表示超时}return 0;                                 // 返回0表示未超时
}

在这里插入图片描述

(7)系统时间定时器中断服务函数( TIM3_IRQHandler())

实现TIM3定时器的中断服务程序,每次定时器溢出时,增加 SystemTimer 计数值,并在计数到60时归零,同时清除中断标志位。

/*********************************************************************@Function  : 系统时间定时器中断服务函数@Parameter : N/A@Return    : N/A
**********************************************************************/
void TIM3_IRQHandler(void)   
{	// 检查定时器更新中断是否触发if(TIM_GetITStatus(TIM3, TIM_IT_Update) == SET) // 溢出中断{SystemTimer++;                                // 系统时间计数器加1if(SystemTimer == 60)	                        // 如果系统时间计数器达到60,则重置为0,并且清零记录的定时器开始时间{	SystemTimer = 0;GetTimer = 0;}}// 清除定时器更新中断标志位TIM_ClearITPendingBit(TIM3, TIM_IT_Update);     // 清除中断标志位
}

在这里插入图片描述

(8)获取系统计时时间函数( GetSystemTimer())

/*********************************************************************@Function  : 获取系统计时时间@Parameter : N/A@Return    : N/A
**********************************************************************/
uint32_t GetSystemTimer(void)
{return SystemTimer;
}

在这里插入图片描述

3、宏定义

步骤1:主函数添加所需的led,主源文件部分报错消失

/***********Hardweare***************/
#include "led.h"

在这里插入图片描述

步骤2:添加宏定义

#define USART_RX_LEN  200               // 接收缓冲区最大长度
#define USART_TX_LEN  200               // 发送缓冲区最大长度
#define UART_NUM      10                // 串口结构体最大对象数量

在这里插入图片描述
步骤3:添加函数声明

void usart1_init(uint32_t bound);
extern USART_DataTypeDef USART_DataTypeStr; 
char USART1_Send_Data(char* Data,uint8_t Lenth);

在这里插入图片描述
步骤4:添加数据类型和宏的头文件

//定义串口数据结构体
typedef struct USART_DataType 
{uint8_t Usart_Rx_Len;          // 接收缓冲区长度uint8_t Usart_Tx_Len;          // 发送缓冲区长度uint8_t Usart_Rx_Num;          // 接收数据计数uint8_t Usart_Tx_Num;          // 发送数据计数uint8_t Usart_Rc_State;        // 接收状态标志位uint8_t Usart_Tc_State;        // 发送状态标志位char Usart_Rx_Buffer[USART_RX_LEN]; // 接收缓冲区char Usart_Tx_Buffer[USART_TX_LEN]; // 发送缓冲区char Usart_Rx_Data[USART_RX_LEN];   // 接收数据char Usart_Tx_Data[USART_TX_LEN];   // 发送数据
} USART_DataTypeDef;

在这里插入图片描述
步骤5:定义一个串口数组变量

USART_DataTypeDef USART_DataTypeStr={0};

在这里插入图片描述

定时器宏定义

步骤1:创建一个宏定义保护

#ifndef __TIMER_H
#define __TIMER_H#endif

在这里插入图片描述

步骤2:添加函数声明

void SystemTinerInit(uint16_t arr,uint16_t psc);//系统时间初始化函数
uint32_t GetSystemTimer(void);                  //获取系统计时时间函数
uint8_t WaitTimerOut(uint32_t gTimer);          //等待计时函数

在这里插入图片描述

步骤3:添加数据类型和宏的头文件

#include <stdint.h> 

在这里插入图片描述

4、知识链接

(1)不同类型的定时器模块

高级、通用和基本定时器是指在STM32微控制器中的不同类型的定时器模块。
在这里插入图片描述

(2)计数器模式

定时器的计数器模式是指定时器以特定时钟频率不断递增计数,当计数值达到预设的值时触发中断或者执行特定的操作。
在这里插入图片描述

(3)STM32中断

使用NVIC统一管理中断,每个中断通道都拥有16个可编程的优先等级,可对优先级进行分组,进一步设置抢占优先级和响应优先级
在这里插入图片描述

5、工程测试

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【论文阅读】Probabilistic Imputation for Time-series Classification with Missing Data

Probabilistic Imputation for Time-series Classification with Missing Data 论文链接&#xff1a;https://icml.cc/virtual/2023/poster/23522 作者&#xff1a;SeungHyun Kim Hyunsu Kim EungGu Yun Hwangrae Lee Jaehun Lee Juho Lee 机构&#xff1a;韩国科学技术…

Qt登录页面

#include "mywidget.h" #include "ui_mywidget.h"MyWidget::MyWidget(QWidget *parent): QWidget(parent), ui(new Ui::MyWidget) {ui->setupUi(this);//接收动图QMovie *mv new QMovie(":/pictrue/luori.gif");ui->loglab->setMovie(…

修复编译RK3568-buildroot时提示不能使用root权限编译的问题

问题 使用 rk3568 的 sdk 中的 buildroot 来编译根文件系统的时候&#xff0c;出现 "you should not run configure as root (set FORCE_UNSAFE_CONFIGURE1 in environment&#xff09;" 的错误。 解决方法 根据错误提示&#xff0c;我们将 set FORCE_UNSAFE_CON…

算法打卡day16

今日任务&#xff1a; 1&#xff09;513.找树左下角的值 2&#xff09;112.路径总和 3&#xff09;113.路径总和Ⅱ 4&#xff09;106.从中序与后序遍历序列构造二叉树 5&#xff09;105.从前序与中序遍历序列构造二叉 513.找树左下角的值 题目链接&#xff1a;513. 找树左下角…

如何在软件测试行业走的更远?

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 时间往前推10年&#xff0c;IT业如日中天。 其中测试更是一个极具包容性的行业。那些希望在技术…

【云开发笔记No.9】Kanban与敏捷开发

Kanban看板起源于丰田。 看板&#xff08;Kanban&#xff09;一词来自日文&#xff0c;本义是可视化卡片。如下图所示&#xff0c;看板工具的实质是&#xff1a;后道工序在需要时&#xff0c;通过看板向前道工序发出信号——请给我需要数量的输入&#xff0c;前道工序只有得到看…

Orangedx:引领新一轮 BTCFi 浪潮

“OrangeDx 作为新一轮 BTCFi 浪潮引领者被市场寄予厚望 &#xff0c;前不久在 FinceptorApp 的平台的公开销售 20 万美元的额度仅在几秒售罄&#xff0c;而其即将以 Startup 方式登陆 Gate 平台也同样备受市场期待。” 自 Ordinals 面向市场为比特币生态带来全新的资产发行方案…

翻过DP这座大山

1.AcWing 跳台阶 第一种方法:暴力搜索DFS #include <iostream> using namespace std;int dfs(int n) {if(n 1) return 1;else if(n 2) return 2;else return dfs(n-1)dfs(n-2); }int main() {int x; cin>>x;cout<<dfs(x)<<endl;return 0; }显然如…

银河麒麟系统安装设备类型选择lvm简单模式之后,数据写入导致失败导致系统重启无法正常加载

银河麒麟系统安装设备类型选择lvm简单模式之后&#xff0c;数据写入导致失败导致系统重启无法正常加载 一 系统环境1.1 系统版本信息1.2 通过镜像安装的过程中选择设备类型选择的是lvm简单模式 二 问题描述三 问题修复过程3.1 挂载ISO镜像&#xff0c;引导到字符终端界面3.2 修…

茶饮品牌抖音账号规划流量运营策划方案

【干货资料持续更新&#xff0c;以防走丢】 茶饮品牌抖音账号规划流量运营策划方案 部分资料预览 资料部分是网络整理&#xff0c;仅供学习参考。 抖音运营资料合集&#xff08;完整资料包含以下内容&#xff09; 目录 冷启动期 1. 直播前期准备 - 进行DOUA/B测试&#xff0…

jupyter操作LSTM模型,词向量模型理解

1.jupyter没有torch模块&#xff0c;参考下面链接的解决办法 【jupyter notebook安装配置教程&#xff0c;导入pytorch解决No module named torch-哔哩哔哩】 https://b23.tv/jYGvyVR 2.jupyter中没有某一模块怎么办&#xff0c;可以用pycharm打开一个项目&#xff0c;在该项…

人工智能三剑客NumPy、pandas、matplotlib和Jupyter四者之间的关系

NumPy 主要用途&#xff1a;NumPy&#xff08;Numerical Python的缩写&#xff09;主要用于处理大型多维数组和矩阵的科学计算。它提供了一个高性能的多维数组对象&#xff0c;以及用于数组操作的工具。与其他三者的联系&#xff1a;NumPy是pandas和matplotlib的基础库之一。许…

网络七层模型之应用层:理解网络通信的架构(七)

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

hcia datacom课程学习(3):http与https、FTP

1.超文本传输协议&#xff1a;http与https &#xff08;1&#xff09;用来访问www万维网。 wwwhttp&#xff0b;html&#xff0b;URLweb &#xff08;2&#xff09;它们提供了一种发布和接受html界面的方法&#xff1a;当在网页输入URL后&#xff0c;从服务器获取html文件来…

Java项目基于Docker打包发布

一、后端项目 1.打包应用 mvn clean package -DskipTests 2、新建dockerfile文件 #基础镜像 FROM openjdk:8 #工作空间 WORKDIR /opt #复制文件 COPY wms-app-1.0-SNAPSHOT.jar app.jar&#xff08;add也可以&#xff09; #配置容器暴漏的端口 EXPOSE 8080 //不暴露端口使用…

软件测试|Python random模块,超乎想象的强大

Python的random模块是一个非常强大的工具&#xff0c;用于生成随机数和随机选择。它提供了许多函数和方法&#xff0c;可以满足各种随机化需求。本文将介绍random模块的基本功能和常见用法&#xff0c;以帮助读者更好地理解和利用这个模块。 返回整数 random.randange() 语法…

关于 FastAPI 路径参数,你知道多少?

你好&#xff0c;我是 shengjk1&#xff0c;多年大厂经验&#xff0c;努力构建 通俗易懂的、好玩的编程语言教程。 欢迎关注&#xff01;你会有如下收益&#xff1a; 了解大厂经验拥有和大厂相匹配的技术等 希望看什么&#xff0c;评论或者私信告诉我&#xff01; 文章目录 一…

React Developer Tools安装

问题描述 在react开发中&#xff0c;需要插件来帮助我们开发&#xff0c;例如&#xff1a; 方法 &#xff08;可能需要魔法 进去后搜索&#xff1a; 点击下载即可

【Nebula笔记】基础操作

目录 一、预备~ 二、基础操作 (一) 图空间 1. 创建图空间 2. 清空图空间 3. 其他 4. FAQ 执行DROP SPACE语句删除图空间后&#xff0c;为什么磁盘的大小没变化&#xff1f; (二) 点类型 1. 创建Tag 2. 删除Tag 3. 更新Tag 4. 其他 (三) 边类型 1. 创建Edge type…

git如何在某个commitId的状态提交到一个分支

有些时候&#xff0c;我们在使用子仓库&#xff0c;或者其他情况&#xff0c;会有一个状态是当前的git仓库是在一个commitId上&#xff0c;而没有在一个分支上&#xff1a; 这时如果想要把基于这个commitId创建一个分支&#xff0c;可以使用下面这个命令&#xff1a; git push…