蓝桥杯嵌入式第12届真题(完成) STM32G431

蓝桥杯嵌入式第12届真题(完成) STM32G431

题目

image-20240215012813131

image-20240215012824875

image-20240215012849030

image-20240215012900044

image-20240215012916324

image-20240215012929908

image-20240215012938452

程序

main.c

/* USER CODE BEGIN Header */
/**
  ******************************************************************************
  * @file           : main.c
  * @brief          : Main program body
  ******************************************************************************
  * @attention
  *
  * <h2><center>&copy; Copyright (c) 2021 STMicroelectronics.
  * All rights reserved.</center></h2>
  *
  * This software component is licensed by ST under BSD 3-Clause license,
  * the "License"; You may not use this file except in compliance with the
  * License. You may obtain a copy of the License at:
  *                        opensource.org/licenses/BSD-3-Clause
  *
  ******************************************************************************
  */
/* USER CODE END Header */
/* Includes ------------------------------------------------------------------*/
#include "main.h"
#include "tim.h"
#include "usart.h"
#include "gpio.h"

/* Private includes ----------------------------------------------------------*/
/* USER CODE BEGIN Includes */
#include "led.h"
#include "key.h"
#include "usart1.h"
#include "stdio.h"
#include "string.h"
/* USER CODE END Includes */

/* Private typedef -----------------------------------------------------------*/
/* USER CODE BEGIN PTD */
uint8_t view = 1;
uint8_t carnums = 8;
uint8_t CNBRnums = 2;
uint8_t VNBRnums = 4;
uint8_t IDLEnums = 2;
float CNBRprice = 3.50f;
float VNBRprice = 2.00f;
uint8_t lcdtext[20];
extern struct Key key[4];
uint8_t pwm = 0;
extern uint8_t rxflag;
extern uint8_t rxdata[1];
extern uint8_t rxindex;
extern uint8_t rxbuffer[22];
uint8_t cartype[4];
uint8_t carnum[4];
uint8_t cartime[12];
uint8_t printtext[30];
struct Times
{
  int year;
	int month;
	int day;
	int hour;
	int min;
};
struct Cars // 串口接收
{
	char carKind[5]; //车型
	char carNum[5];  //车牌号
	char carTime[12]; //进入时间
	struct Times Time;
};

struct Cars car;
struct Cars park[8]={0,0,0,0,0,0,0,0}; 
float stopprice;
uint8_t led,led1enable,led2enable;
int monthDays[12] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
uint8_t isError = 0;
/* USER CODE END PTD */

/* Private define ------------------------------------------------------------*/
/* USER CODE BEGIN PD */
/* USER CODE END PD */

/* Private macro -------------------------------------------------------------*/
/* USER CODE BEGIN PM */

/* USER CODE END PM */

/* Private variables ---------------------------------------------------------*/

/* USER CODE BEGIN PV */

/* USER CODE END PV */

/* Private function prototypes -----------------------------------------------*/
void SystemClock_Config(void);
/* USER CODE BEGIN PFP */
void key_process(void);
void usart1_process(void);
void lcd_process(void);
void led_process(void);
void outpark(uint8_t car_num);
void inpark(void);
void isErrorProcess(void);
void lcdclear(void);
int isLeapYear(int year);
long dateToTotalMinutes(struct Times t);
/* USER CODE END PFP */

/* Private user code ---------------------------------------------------------*/
/* USER CODE BEGIN 0 */

/* USER CODE END 0 */

/**
  * @brief  The application entry point.
  * @retval int
  */
int main(void)
{
  /* USER CODE BEGIN 1 */

  /* USER CODE END 1 */

  /* MCU Configuration--------------------------------------------------------*/

  /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  HAL_Init();

  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* Configure the system clock */
  SystemClock_Config();

  /* USER CODE BEGIN SysInit */

  /* USER CODE END SysInit */

  /* Initialize all configured peripherals */
  MX_GPIO_Init();
  MX_TIM2_Init();
  MX_TIM17_Init();
  MX_USART1_UART_Init();
	HAL_TIM_Base_Start_IT(&htim2);
	HAL_UART_Receive_IT(&huart1,rxdata,1);
  /* USER CODE BEGIN 2 */

    LCD_Init();
		lcdclear();
		led_Display(0x00);
  /* USER CODE END 2 */

  /* Infinite loop */
  /* USER CODE BEGIN WHILE */



   

    while (1)
    {
				key_process();
				usart1_process();
				lcd_process();
				led_process();
			isErrorProcess();
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
    }
  /* USER CODE END 3 */
}

/**
  * @brief System Clock Configuration
  * @retval None
  */
void SystemClock_Config(void)
{
  RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
  RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};

  /** Configure the main internal regulator output voltage
  */
  HAL_PWREx_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE1);
  /** Initializes the RCC Oscillators according to the specified parameters
  * in the RCC_OscInitTypeDef structure.
  */
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
  RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI;
  RCC_OscInitStruct.PLL.PLLM = RCC_PLLM_DIV2;
  RCC_OscInitStruct.PLL.PLLN = 20;
  RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2;
  RCC_OscInitStruct.PLL.PLLQ = RCC_PLLQ_DIV2;
  RCC_OscInitStruct.PLL.PLLR = RCC_PLLR_DIV2;
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  {
    Error_Handler();
  }
  /** Initializes the CPU, AHB and APB buses clocks
  */
  RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
                              |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
  RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;

  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
  {
    Error_Handler();
  }
  /** Initializes the peripherals clocks
  */
  PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_USART1;
  PeriphClkInit.Usart1ClockSelection = RCC_USART1CLKSOURCE_PCLK2;
  if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
  {
    Error_Handler();
  }
}

/* USER CODE BEGIN 4 */
void key_process(void)
{
	if(key[0].key_single_flag)
	{
		key[0].key_single_flag = 0;
		if(view==1)
		{
			view = 2;
		}else{
			view = 1;
		}
		
	}
	if(key[1].key_single_flag)
	{
		key[1].key_single_flag = 0;
		if(view==2)
		{
			CNBRprice+=0.5f;
			VNBRprice+=0.5f;
			
		}
	}
	if(key[2].key_single_flag)
	{
		key[2].key_single_flag = 0;
		if(view==2)
		{
			CNBRprice-=0.5f;
			VNBRprice-=0.5f;
			
		}
	}
	if(key[3].key_single_flag)
	{
		key[3].key_single_flag = 0;
		pwm=!pwm;
		if (pwm)
		{
			HAL_TIM_PWM_Start(&htim17,TIM_CHANNEL_1);
			__HAL_TIM_SET_COMPARE(&htim17,TIM_CHANNEL_1,200);
		}else{
			
			HAL_TIM_PWM_Stop(&htim17, TIM_CHANNEL_1); // 停止PWM
			HAL_GPIO_WritePin(GPIOA, GPIO_PIN_7, GPIO_PIN_RESET); // 设置PA7为低电平
		}
	}
	
}
void outpark(uint8_t car_num)
{
   
		sscanf(car.carTime, "%4d%2d%2d%2d%2d", &car.Time.year, &car.Time.month, &car.Time.day, &car.Time.hour, &car.Time.min);
    // 计算两个时间点的总分钟数
    long carTimeInMin = dateToTotalMinutes(car.Time);
    long parkTimeInMin = dateToTotalMinutes(park[car_num].Time);
    // 计算经过的总时间(以分钟为单位),并转换为小时
    long diffInMin = carTimeInMin - parkTimeInMin;
    int hoursPassed = diffInMin / 60;
    // 如果不满一小时,则按一小时计算
    if(diffInMin % 60 > 0) {
        hoursPassed++;
    }

    // 保证至少为1小时
    if(hoursPassed <= 0) {
        hoursPassed = 1;
    }
		if(strcmp(car.carKind,"VNBR") ==0)
		{
			VNBRnums --;
			IDLEnums ++;
			stopprice=hoursPassed*VNBRprice;
		}else if(strcmp(car.carKind,"CNBR") ==0)
		{
			CNBRnums --;
			IDLEnums ++;
			stopprice=hoursPassed*CNBRprice;
		}
		memset(&park[car_num],0,sizeof(park[car_num]));
    sprintf((char *)printtext,"%s:%s:%d:%.2f\r\n",car.carKind,car.carNum,hoursPassed,stopprice);
		HAL_UART_Transmit(&huart1,printtext,strlen((char *)printtext),50);

    
}

void inpark(void)
{
		sscanf(car.carTime, "%4d%2d%2d%2d%2d", &car.Time.year, &car.Time.month, &car.Time.day, &car.Time.hour, &car.Time.min);
    for (int i = 0; i < 8; i++) {
        // 查找第一个空位
        if (park[i].carNum[0] == '\0') { // 假设未使用的车位carNum为'\0'
            park[i] = car;

            // 更新车位统计信息
            if (strcmp(car.carKind, "CNBR") == 0) {
                CNBRnums++;
                IDLEnums--;
            } else if (strcmp(car.carKind, "VNBR") == 0) {
                VNBRnums++;
                IDLEnums--;
            }

            break; // 退出循环
        }
    }

}


void usart1_process(void)
{
	if(rxflag)
	{
		rxflag = 0;
		rxindex = 0;
		int parsedItems = sscanf((char*)rxbuffer,"%4s:%4s:%12s",car.carKind,car.carNum,car.carTime);
		if(parsedItems == 3)
		{
			if(strcmp(car.carKind,"CNBR")==0||strcmp(car.carKind,"VNBR")==0)//格式正确
			{
				for(int i = 0;i < 8;i++)
				{
					if(strcmp(park[i].carNum,car.carNum)==0) //车库中有,需要出库
					{
						if(strcmp(park[i].carKind,car.carKind) == 0)
						{
							outpark(i);
							break;
						}else{
							isError = 1;
						}
					}else if(strcmp(park[i].carNum,car.carNum)!=0&&IDLEnums>0)//车库中没有需要,入库
					{
						inpark();
						break;
					}
				}
			
			}else
        {
            isError = 1;
        }
			
		}else
			{
					isError = 1;
			}
		rxflag = 0;
		rxindex = 0;
		HAL_UART_Receive_IT(&huart1,rxdata,1);
	}
}

void isErrorProcess(void)
{
	if(isError == 1)
	{
		sprintf((char *)printtext,"Error\r\n");
		HAL_UART_Transmit(&huart1,(uint8_t*)printtext,strlen((char *)printtext),50);
		isError = 0;
	}
}
void lcd_process(void)
{
	switch (view)
  {
  	case 1://车位显示页面
		{
			sprintf((char *)lcdtext,"       Data");
			LCD_DisplayStringLine(Line1,lcdtext);
			sprintf((char *)lcdtext,"  CNBR:%d",CNBRnums);
			LCD_DisplayStringLine(Line3,lcdtext);
			sprintf((char *)lcdtext,"  VNBR:%d",VNBRnums);
			LCD_DisplayStringLine(Line5,lcdtext);
			sprintf((char *)lcdtext,"  IDLE:%d",IDLEnums);
			LCD_DisplayStringLine(Line7,lcdtext);
		}
  	break;
  	case 2: //费率设置页面
		{
			sprintf((char *)lcdtext,"       Para");
			LCD_DisplayStringLine(Line1,lcdtext);
			sprintf((char *)lcdtext,"  CNBR:%.2f",CNBRprice);
			LCD_DisplayStringLine(Line3,lcdtext);
			sprintf((char *)lcdtext,"  VNBR:%.2f",VNBRprice);
			LCD_DisplayStringLine(Line5,lcdtext);
		}
  		break;
  }
}
void led_process(void)
{
	if(IDLEnums>0)
	{
		led1enable = 1;
	}else{
		led1enable = 0;
	}
	if(pwm==1)
	{
		led2enable = 1;
	}else{
		led2enable = 0;
	}
	if(led1enable)
	{
		led|=0x01;
	}else{
		led&=~0x01;
	}
	if(led2enable)
	{
		led|=0x02;
	}else{
		led&=~0x02;
	}
	led_Display(led);
}

void lcdclear()
{
    LCD_Clear(Black);
    LCD_SetBackColor(Black);
    LCD_SetTextColor(White);
}

int isLeapYear(int year) {
    if (year % 4 != 0) return 0;
    if (year % 100 != 0) return 1;
    if (year % 400 == 0) return 1;
    return 0;
}
long dateToTotalMinutes(struct Times t) {
    // 添加之前的年份所包含的分钟数
    long totalMinutes = (t.year - 1) * 365 * 24 * 60;
    
    // 添加闰年的额外分钟数
    totalMinutes += ((t.year - 1) / 4 - (t.year - 1) / 100 + (t.year - 1) / 400) * 24 * 60;
    
    // 添加当前年份中之前月份的分钟数
    for (int i = 0; i < t.month - 1; i++) {
        totalMinutes += monthDays[i] * 24 * 60;
    }
    
    // 如果当前年份是闰年并且月份大于2,则额外添加一天的分钟数
    if (t.month > 2 && isLeapYear(t.year)) totalMinutes += 24 * 60;
    
    // 添加当前月份中的天数、小时和分钟
    totalMinutes += (t.day - 1) * 24 * 60; // 天数减1,因为当天不满24小时
    totalMinutes += t.hour * 60;
    totalMinutes += t.min;

    return totalMinutes;
}
/* USER CODE END 4 */

/**
  * @brief  This function is executed in case of error occurrence.
  * @retval None
  */
void Error_Handler(void)
{
  /* USER CODE BEGIN Error_Handler_Debug */
    /* User can add his own implementation to report the HAL error return state */

  /* USER CODE END Error_Handler_Debug */
}

#ifdef  USE_FULL_ASSERT
/**
  * @brief  Reports the name of the source file and the source line number
  *         where the assert_param error has occurred.
  * @param  file: pointer to the source file name
  * @param  line: assert_param error line source number
  * @retval None
  */
void assert_failed(uint8_t *file, uint32_t line)
{
  /* USER CODE BEGIN 6 */
    /* User can add his own implementation to report the file name and line number,
       tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  /* USER CODE END 6 */
}
#endif /* USE_FULL_ASSERT */

/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/

key.c

#include "key.h"
struct Key key[4]={0,0,0,0};
void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
	if(htim->Instance==TIM2)
	{
		 key[0].key_gpio =  HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_0);
		 key[1].key_gpio =  HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_1);
		 key[2].key_gpio =  HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_2);
		 key[3].key_gpio =  HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_0);
		 for(int i = 0;i<4;i++)
     {
			 switch (key[i].key_status)
       {
				 case 0:
				{
					if(key[i].key_gpio==0)
					{
						key[i].key_status = 1;
					}
				}
       		break;
       	case 1:
				{
					if(key[i].key_gpio==0)
					{
						key[i].key_single_flag = 1;
						key[i].key_status = 2;
					}else{
						key[i].key_status = 0;
					}
				}
       		break;
       	case 2:
				{
					if(key[i].key_gpio==1)
					{
						
						key[i].key_status = 0;
					}
					
				}
       	break;
       }
     }
	}
	
}

led.c

#include "led.h"

void led_Display(uint8_t led)
{
	HAL_GPIO_WritePin(GPIOC,GPIO_PIN_All,GPIO_PIN_SET);
	HAL_GPIO_WritePin(GPIOD,GPIO_PIN_2,GPIO_PIN_SET);
	HAL_GPIO_WritePin(GPIOD,GPIO_PIN_2,GPIO_PIN_RESET);
	HAL_GPIO_WritePin(GPIOC,led<<8,GPIO_PIN_RESET);
	HAL_GPIO_WritePin(GPIOD,GPIO_PIN_2,GPIO_PIN_SET);
	HAL_GPIO_WritePin(GPIOD,GPIO_PIN_2,GPIO_PIN_RESET);
}


usart1.c

#include "usart1.h"
#include "usart.h"
#include "string.h"
uint8_t rxflag;
uint8_t rxdata[1];
uint8_t rxindex = 0;
uint8_t rxbuffer[22];

void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{
		if(huart->Instance==USART1)
		{
			rxbuffer[rxindex++] = rxdata[0];
			HAL_UART_Receive_IT(huart,rxdata,1);
			if(rxindex==22)
			{
				rxflag = 1;
			}
		}

}

程序很常规,只有串口那里处理比较麻烦,有几个注意事项

  • 使用或和与操作实现单独对led某一位进行操作
  • 需要判断闰年
  • 处理错误,有好几种
  • sscanf解析字符串

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

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

相关文章

【业务功能篇135】多线程+countDownLatch执行大数据量定时任务

对于业务中存在一些功能需求&#xff0c;业务逻辑复杂且数据量大&#xff0c;过程处理也就比较繁琐&#xff0c;如果直接在单线程同步执行&#xff0c;效率就比较低了&#xff0c;所以我们需要利用多线程&#xff0c;开启多个线程去把任务分线程异步执行&#xff0c;这些效率就…

【java】小学生数学练习题目生成系统

本文章主要是CSDN-问答板块&#xff0c;有题主提出的问题&#xff0c;我这边将完整代码提供出来&#xff0c;仅供大家参考学习&#xff01; 一、效果截图 二、直接上代码 package com.example.dingtalk.question;import javax.script.ScriptEngine; import javax.script.Scrip…

点成分享|如何让地球更绿,它能给你答案

一、背景介绍 随着全球经济的飞速发展&#xff0c;环境问题也日益严重。现代社会面临着诸如全球变暖、气候异常、空气和水质污染等诸多环境问题。其中&#xff0c;温室气体的排放是导致全球变暖的主要原因之一。温室气体的排放量上升加剧气候异常&#xff0c;影响人类生存和自…

NFC三大工作模式及其在物联网应用实例

NFC支持三种通信模式&#xff1a;读写模式、点对点模式和卡模拟模式。在此三种模式下&#xff0c;都仅需简单点击便可启动传输。 在读写模式下&#xff0c;系统执行非接触式读写功能。该系统的NFC芯片与内置NFC的设备-诸如非接触式智能卡、NFC标签或具有NFC功能的智能手机&…

瑞盟MS5188N——16bit、8 通道、500kSPS、 SAR 型 ADC

产品简述 MS5188N 是 8 通道、 16bit 、电荷再分配逐次逼近型模数 转换器&#xff0c;采用单电源供电。 MS5188N 拥有多通道、低功耗数据采集系统所需的所有 组成部分&#xff0c;包括&#xff1a;无失码的真 16 位 SAR ADC &#xff1b;用于将输入配 置为单端输入…

unity学习(31)——跳转到角色选择界面(打勾?手滑挂错脚本)

There are 2 audio listeners in the scene. Please ensure there is always exactly one audio listener in the scene. 是因为后来创建了一个camera&#xff0c;因为camera中自带一个组件Audio Listener。所以有两个camera就有两个audio listener导致报错。 一个简单的解决…

WebRTC最新版报错解决:city.wav:missing and no known rule to make it (二十六)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏:多媒体系统工程师系列【原创干货持续更新中……】🚀 人生格言: 人生从来没有捷径,只…

读懂2024年数字孪生发展新趋势!十大权威白皮书放送!

2024年&#xff0c;数字孪生 该往哪些方向走&#xff1f; 新技术的不断涌现 又会带来怎样的行业变迁 …… 在开工之际&#xff0c;我们整理了 51WORLD主导、参编的 十大权威数字孪生白皮书、行业报告 以及产业优秀案例集 分享给想要提升自我的朋友们 读完这些 上面看似…

【数据结构】时间复杂度与空间复杂度

时间复杂度 算法的时间复杂度并不是指一个代码运行时间的快慢&#xff0c;因为在不同机器上运行的时间肯定不同&#xff0c;因此算法的时间复杂度指的是基本操作的执行次数&#xff0c;他是一个数学意义上的函数。这个函数并不是C语言中那种函数&#xff0c;而是一个数学函数&…

WebGL中开发科学数据可视化应用

WebGL在科学数据可视化领域有广泛的应用&#xff0c;可以用于呈现和解释复杂的科学数据。以下是在WebGL中开发科学数据可视化应用时的一些建议&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#xff0c;欢迎交流合作。 1.选择合…

网络原理 - HTTP/HTTPS(4)

HTTP响应详解 认识"状态码"(status code) 状态码表示访问一个页面的结果.(是访问成功,还是失败,还是其它的一些情况...).(响应结果如何) 学习状态码 -> 为了调试问题. 写服务器时,按照状态码的含义正确使用. 200 OK 这是最常见的状态码,表示访问成功. 抓包抓…

Android加载富文本

直接用webview加载&#xff1a; package com.example.testcsdnproject;import androidx.appcompat.app.AppCompatActivity;import android.annotation.SuppressLint; import android.graphics.Color; import android.os.Bundle; import android.util.Log; import android.webk…

docker (十一)-进阶篇-docker-compos最佳实践部署zabbix

一 部署docker环境 关闭防火墙、selinux、开启docker&#xff0c;并设置开机自启动 注意点&#xff1a;docker部署的时候&#xff0c;bip要指定&#xff0c;不然会导致虚拟机ip和容器ip冲突&#xff0c;ssh连不上虚拟机 部署请参考 docker &#xff08;二&#xff09;-yum…

数据库管理-第153期 Oracle Vector DB AI-05(20240221)

数据库管理153期 2024-02-21 数据库管理-第153期 Oracle Vector DB & AI-05&#xff08;20240221&#xff09;1 Oracle Vector的其他特性示例1&#xff1a;示例2 2 简单使用Oracle Vector环境创建包含Vector数据类型的表插入向量数据 总结 数据库管理-第153期 Oracle Vecto…

计算机服务器中了devos勒索病毒怎么办?Devos勒索病毒解密数据恢复

网络技术的不断发展与更新&#xff0c;为企业的生产运营提供了有利保障&#xff0c;企业的生产运营离不开数据支撑&#xff0c;通过企业数据可以综合调整发展运营方向&#xff0c;但网络是一把双刃剑&#xff0c;近期&#xff0c;云天数据恢复中心接到许多企业的求助&#xff0…

2.20 Qt day1

一. 思维导图 二. 消化常用类的使用&#xff0c;以及常用成员函数对应的功能 按钮类QPushButton&#xff1a; mywidget.h&#xff1a; #ifndef MYWIDGET_H #define MYWIDGET_H#include <QWidget> #include<QPushButton>//按钮类 #include<QIcon>class MyW…

ts快速入门

文章目录 一、运行环境1、线上Playground2、VSCode 编辑器3、Code Runner 插件4、ts-node 二、声明1、变量声明2、常量声明3、类型推断 三、常用数据类型1、number2、string3、boolean4、数组5、对象 四、函数1、函数声明语法2、参数详解&#xff08;1&#xff09;特殊语法&…

C++学习Day08之类模板碰到继承的问题以及解决

目录 一、程序及输出1.1 指定父类T数据类型1.2 子类T指定父类T数据类型 二、分析与总结 一、程序及输出 1.1 指定父类T数据类型 必须要指定出父类中的T数据类型&#xff0c;才能给子类分配内存 正确使用 &#xff1a; #include<iostream> using namespace std;templa…

webpack打包速度优化思维导图

webpack打包速度优化思维导图 前言附件 前言 去年的时候公司一个项目体积过大&#xff0c;我是m1芯片的macpro&#xff0c;光启动就要1分钟&#xff0c;配置差点都电脑&#xff0c;启动就要3分钟&#xff0c;自然打包速度也会慢很多&#xff0c;我们是gitlab设置成了自动打包的…

春招面试准备笔记——NMS(非极大值抑制)算法

NMS&#xff08;非极大值抑制&#xff09;算法非极大值抑制是用于减少物体检测算法中重叠边界框或区域的数量的技术。通过对每个类别的检测框按置信度排序&#xff0c;然后逐个遍历&#xff0c;保留置信度最高的框&#xff0c;并抑制与其重叠且置信度低的框&#xff0c;从而得到…