物联网||不一样的点灯实验(2)|通过使用CMSIS库函数实现点灯实验-学习笔记(12)

文章目录

  • 通过使用CMSIS库函数实现点灯实验
    • 1 如何使用CMIS库
    • 2 如何利用CMSIS库操作IO
  • 两种实现方法的比较
  • 课后作业:
    • 完整代码:
      • LED.C:
      • test.c:
      • led.h:
      • systick.h:
      • systick.c:

通过使用CMSIS库函数实现点灯实验

1 如何使用CMIS库


   #####如何使用此驱动#####
   ==============================================================================
   [. .]
   (#)启用GPIO AHB时钟使用以下函数:__HAL_RCC_GPIOx_CLK_ENABLE()(#)使用HAL_GPIO_Init()配置GPIO引脚。
   (++)使用GPIO_InitTypeDef结构体中的“mode”成员配置IO模式
   (++)激活上拉,下拉电阻使用“拉”成员从GPIO_InitTypeDef结构。
   (++)在输出或交替功能模式选择时:速度为通过GPIO_InitTypeDef结构中的“Speed”成员配置。
   (++)在备用模式下为选择,备用功能连接IO通过GPIO_InitTypeDef结构中的“Alternate”成员配置。
   (++)当引脚用作ADC通道时,需要模拟模式或DAC输出。
   (++)在外部中断/事件的情况下,选择“Mode”成员从GPIO_InitTypeDef结构选择类型(中断或事件)和相应的触发事件(上升或下降或两者都有)。

   在外部中断/事件模式选择的情况下,配置NVIC IRQ优先级使用HAL_NVIC_SetPriority()映射到EXTI行,并使用HAL_NVIC_EnableIRQ()(#)使用HAL_GPIO_ReadPin()获取在输入模式下配置的引脚电平。

   (#)设置/重置在输出模式下配置的引脚的电平
   HAL_GPIO_WritePin () / HAL_GPIO_TogglePin()(#)锁定引脚配置直到下一次重置使用HAL_GPIO_LockPin()(#)复位期间和复位后,备用功能不存在active,且GPIO引脚配置为输入浮动模式(JTAG除外))(#) LSE振荡器引脚OSC32_IN和OSC32_OUT可作为通用器件使用(PC14和PC15),当LSE振荡器关闭时,LSE优先于GPIO功能。。
   (#) HSE振荡器引脚OSC_IN/OSC_OUT可用作通用PH0和PH1,当HSE振荡器关闭时。HSE优先于GPIO功能。
   初始化:void HAL_GPIO_Init(GPIO_TypeDef  *GPIOx, GPIO_InitTypeDef *GPIO_Init)
   输入参数检查:
   /* Check the parameters */
   assert_param(IS_GPIO_ALL_INSTANCE(GPIOx));
   assert_param(IS_GPIO_PIN(GPIO_Init->Pin));
   assert_param(IS_GPIO_MODE(GPIO_Init->Mode));
类似的处理,厂家的代码更加健壮。
引用库后需要先编译一下, 才能出现头文件.h。

2 如何利用CMSIS库操作IO

根据 Enable the GPIO AHB clock using the following function: __HAL_RCC_GPIOx_CLK_ENABLE(). 初始化需首先调用 __HAL_RCC_GPIOx_CLK_ENABLE()

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

     void LED0_Init(void)
		{
		
			__HAL_RCC_GPIOF_CLK_ENABLE();
		
		}
提示警告:
打开stm32f4xx_hal_rcc_ex.h:
端口F的初始化宏定义:
    #define __HAL_RCC_GPIOF_CLK_ENABLE()    do { \
                                        __IO uint32_t tmpreg = 0x00U; \
                                        SET_BIT(RCC->AHB1ENR, RCC_AHB1ENR_GPIOFEN);\
                                        /* Delay after an RCC peripheral clock enabling */ \
                                        tmpreg = READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_GPIOFEN);\
                                        UNUSED(tmpreg); \
                                        } while(0U)

需要将头文件包含在代码中去。
在这里插入图片描述
加入初始化stm32f4xx_hal_gpio.c中的void HAL_GPIO_Init(GPIO_TypeDef *GPIOx, GPIO_InitTypeDef *GPIO_Init),增加函数:HAL_GPIO_Init(GPIO_TypeDef *GPIOx, GPIO_InitTypeDef *GPIO_Init)
参数1为:GPIOF,参数2为: gpio_info
先定义结构体参数gpio_info:GPIO_InitTypeDef gpio_info,而GPIO_InitTypeDef的定义在:#include "stm32f4xx_hal_gpio.h"中,引入:
在这里插入图片描述

提示错误:在这里插入图片描述

取地址,根据提示增加&,解决。
开始写gpio_info的参数,取值在"stm32f4xx_hal_gpio.h"中进行了定义,直接使用宏定义的值:
在这里插入图片描述

	gpio_info.Mode = GPIO_MODE_OUTPUT_PP;

定义速度Speed,头文件中的定义为:

            /** @defgroup GPIO_speed_define  GPIO speed define
        * @brief GPIO Output Maximum frequency
        * @{
        */
        #define  GPIO_SPEED_FREQ_LOW         0x00000000U  /*!< IO works at 2 MHz, please refer to the product datasheet */
        #define  GPIO_SPEED_FREQ_MEDIUM      0x00000001U  /*!< range 12,5 MHz to 50 MHz, please refer to the product datasheet */
        #define  GPIO_SPEED_FREQ_HIGH        0x00000002U  /*!< range 25 MHz to 100 MHz, please refer to the product datasheet  */
        #define  GPIO_SPEED_FREQ_VERY_HIGH   0x00000003U  /*!< range 50 MHz to 200 MHz, please refer to the product datasheet  */
        /**
        * @}
        */

其他可设置的模式:

           /** @defgroup GPIO_mode_define GPIO mode define
       * @brief GPIO Configuration Mode
       *        Elements values convention: 0x00WX00YZ
       *           - W  : EXTI trigger detection on 3 bits
       *           - X  : EXTI mode (IT or Event) on 2 bits
       *           - Y  : Output type (Push Pull or Open Drain) on 1 bit
       *           - Z  : GPIO mode (Input, Output, Alternate or Analog) on 2 bits
       * @{
       */
       #define  GPIO_MODE_INPUT                        MODE_INPUT                                                  /*!< Input Floating Mode                   */
       #define  GPIO_MODE_OUTPUT_PP                    (MODE_OUTPUT | OUTPUT_PP)                                   /*!< Output Push Pull Mode                 */
       #define  GPIO_MODE_OUTPUT_OD                    (MODE_OUTPUT | OUTPUT_OD)                                   /*!< Output Open Drain Mode                */
       #define  GPIO_MODE_AF_PP                        (MODE_AF | OUTPUT_PP)                                       /*!< Alternate Function Push Pull Mode     */
       #define  GPIO_MODE_AF_OD                        (MODE_AF | OUTPUT_OD)                                       /*!< Alternate Function Open Drain Mode    */

       #define  GPIO_MODE_ANALOG                       MODE_ANALOG                                                 /*!< Analog Mode  */

       #define  GPIO_MODE_IT_RISING                    (MODE_INPUT | EXTI_IT | TRIGGER_RISING)                     /*!< External Interrupt Mode with Rising edge trigger detection          */
       #define  GPIO_MODE_IT_FALLING                   (MODE_INPUT | EXTI_IT | TRIGGER_FALLING)                    /*!< External Interrupt Mode with Falling edge trigger detection         */
       #define  GPIO_MODE_IT_RISING_FALLING            (MODE_INPUT | EXTI_IT | TRIGGER_RISING | TRIGGER_FALLING)   /*!< External Interrupt Mode with Rising/Falling edge trigger detection  */

       #define  GPIO_MODE_EVT_RISING                   (MODE_INPUT | EXTI_EVT | TRIGGER_RISING)                     /*!< External Event Mode with Rising edge trigger detection             */
       #define  GPIO_MODE_EVT_FALLING                  (MODE_INPUT | EXTI_EVT | TRIGGER_FALLING)                    /*!< External Event Mode with Falling edge trigger detection            */
       #define  GPIO_MODE_EVT_RISING_FALLING           (MODE_INPUT | EXTI_EVT | TRIGGER_RISING | TRIGGER_FALLING)   /*!< External Event Mode with Rising/Falling edge trigger detection     */

       /**
       * @}
       */
       /** @defgroup GPIO_pull_define GPIO pull define
       * @brief GPIO Pull-Up or Pull-Down Activation
       * @{
       */
       #define  GPIO_NOPULL        0x00000000U   /*!< No Pull-up or Pull-down activation  */
       #define  GPIO_PULLUP        0x00000001U   /*!< Pull-up activation                  */
       #define  GPIO_PULLDOWN      0x00000002U   /*!< Pull-down activation                */
       /**
       * @}
       */
       ```
       定义要操作的端口,gpio_info.Pin:gpio_info.Pin = GPIO_PIN_9;
       来源:"stm32f4xx_hal_gpio.h":
       ```C
       /** @defgroup GPIO_pins_define GPIO pins define
       * @{
       */
       #define GPIO_PIN_0                 ((uint16_t)0x0001)  /* Pin 0 selected    */
       #define GPIO_PIN_1                 ((uint16_t)0x0002)  /* Pin 1 selected    */
       #define GPIO_PIN_2                 ((uint16_t)0x0004)  /* Pin 2 selected    */
       #define GPIO_PIN_3                 ((uint16_t)0x0008)  /* Pin 3 selected    */
       #define GPIO_PIN_4                 ((uint16_t)0x0010)  /* Pin 4 selected    */
       #define GPIO_PIN_5                 ((uint16_t)0x0020)  /* Pin 5 selected    */
       #define GPIO_PIN_6                 ((uint16_t)0x0040)  /* Pin 6 selected    */
       #define GPIO_PIN_7                 ((uint16_t)0x0080)  /* Pin 7 selected    */
       #define GPIO_PIN_8                 ((uint16_t)0x0100)  /* Pin 8 selected    */
       #define GPIO_PIN_9                 ((uint16_t)0x0200)  /* Pin 9 selected    */
       #define GPIO_PIN_10                ((uint16_t)0x0400)  /* Pin 10 selected   */
       #define GPIO_PIN_11                ((uint16_t)0x0800)  /* Pin 11 selected   */
       #define GPIO_PIN_12                ((uint16_t)0x1000)  /* Pin 12 selected   */
       #define GPIO_PIN_13                ((uint16_t)0x2000)  /* Pin 13 selected   */
       #define GPIO_PIN_14                ((uint16_t)0x4000)  /* Pin 14 selected   */
       #define GPIO_PIN_15                ((uint16_t)0x8000)  /* Pin 15 selected   */
       #define GPIO_PIN_All               ((uint16_t)0xFFFF)  /* All pins selected */

       #define GPIO_PIN_MASK              0x0000FFFFU /* PIN mask for assert test */
       /**
       * @}
       */
   ```
其他参数采用复位值即可。
配置端口为高电平,用到的函数为HAL_GPIO_WritePin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin, GPIO_PinState PinState):
GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin定义按前述变量填写。
GPIO_PinStatw定义为enmu,枚举变量,定义为:
```C
/**
 * @brief  GPIO Bit SET and Bit RESET enumeration
 */
typedef enum
{
 GPIO_PIN_RESET = 0,
 GPIO_PIN_SET
}GPIO_PinState;
/**
 * @}
 */

此处定义为:GPIO_PIN_SET,初始化完成后,默认为不亮的。

两种实现方法的比较

  • 更好的可移植性
  • 更好的可靠性
  • 代码占用的空间
  • 更大更好的使用性

课后作业:

1:如何写一个更加通用移植性更好的控制灯的函数
利用库函数控制:

void Led_Ctrl(GPIo_TypeDef* GPIOx,uint16_t led_pin,uint8_t ctrl)
{
    if(LED_ON==ctrl)
       HAL_GPIO_WritePin(GPIOx, led_pin, GPIO_PIN_RESET);
    else
       HAL_GPIO_WritePin(GPIOx, led_pin, GPIO_PIN_SET);
}

重新编译工程标准库的GPIO功能的时候出现了error: #20: identifier “HAL_StatusTypeDef” is undefined问题。
在这里插入图片描述
解决方式:#include "stm32f4xx_hal.h"后,添加user目录下的test.c(有main函数即可),成功编译。在这里插入图片描述

include目录可添加指定目录:在这里插入图片描述
另外,GPIO_InitTypeDef 也可以采用指针形式,如: *p_gpio_info;

对指针的存储空间进行分配,用malloc

GPIO_InitTypeDef  *p_gpio_info; //方法2:定义指针
p_gpio_info = malloc(sizeof(GPIO_InitTypeDef));//如警告没有声明,则需要引用标准库:#include "stdlib.h"

更多的操作说明,以stm32f4xx_hal.c为例,提供了常用的硬件相关的API:
The HAL contains two APIs’ categories:
(+) Common HAL APIs
(+) Services HAL APIs
如:初始化HAL_StatusTypeDef HAL_Init(void)
主堆栈初始化:
/**

  • @brief Initialize the MSP.
  • @retval None
    */
    __weak void HAL_MspInit(void)
    延时函数:
    __weak void HAL_Delay(uint32_t Delay)
    {
    uint32_t tickstart = HAL_GetTick();
    uint32_t wait = Delay;

/* Add a freq to guarantee minimum wait */
if (wait < HAL_MAX_DELAY)
可以尝试采用。

完整代码:

LED.C:


#include "stm32f4xx_hal.h"
#include "stm32f4xx_hal_rcc.h"
#include "stm32f4xx_hal_gpio.h"
#include "stdlib.h"
#include "stm32f4xx.h"
#include "systick.h"
#include "led.h"


void LED0_Init(void)
{

	GPIO_InitTypeDef  gpio_info;
	
	GPIO_InitTypeDef  *p_gpio_info; //方法2:定义指针
	
	p_gpio_info = malloc(sizeof(GPIO_InitTypeDef));//如警告没有声明,则需要引用标准库:#include "stdlib.h"
	
	__HAL_RCC_GPIOF_CLK_ENABLE();
	
	p_gpio_info->Pin = GPIO_PIN_10; //方法2:指针赋值
	p_gpio_info->Mode = GPIO_MODE_OUTPUT_PP;
	p_gpio_info->Speed = GPIO_SPEED_FREQ_MEDIUM;
	
	
	gpio_info.Pin = GPIO_PIN_9;
	gpio_info.Mode = GPIO_MODE_OUTPUT_PP;
	gpio_info.Speed = GPIO_SPEED_FREQ_MEDIUM; //其他参数采用复位值即可
	
	HAL_GPIO_Init(GPIOF, &gpio_info);
	
	//HAL_GPIO_Init(GPIOF,p_gpio_info); //方法2
	
	HAL_GPIO_WritePin(GPIOF, GPIO_PIN_9, GPIO_PIN_SET);
	
	
}

void LED0_On()
{
	
	HAL_GPIO_WritePin(GPIOF, GPIO_PIN_9, GPIO_PIN_RESET);
	HAL_GPIO_WritePin(GPIOF, GPIO_PIN_10, GPIO_PIN_SET);
}

void LED0_Off()
{

	HAL_GPIO_WritePin(GPIOF, GPIO_PIN_9, GPIO_PIN_SET);
	HAL_GPIO_WritePin(GPIOF, GPIO_PIN_10, GPIO_PIN_SET);
	
}

void Led_Ctrl(GPIO_TypeDef* GPIOx,uint16_t led_pin,uint8_t ctrl)
{
    if(LED_ON==ctrl)
       HAL_GPIO_WritePin(GPIOx, led_pin, GPIO_PIN_RESET);
    else
       HAL_GPIO_WritePin(GPIOx, led_pin, GPIO_PIN_SET);
}

test.c:

#include "systick.h"
#include "stm32f4xx.h"
#include "led.h"

#define SYS_MAX_CLK 12
#define DELAY_1S    1000

int main(void)
{
	
	LED0_Init();//初始化LEDO
  delay_init(SYS_MAX_CLK);//初始化系统时钟
	
	while(1)
	{
		/*
		LED0_On(); //点亮LEDO
		delay_ms(1000); //延时1s
		LED0_Off(); //关闭LED0
		//delay_ms(1000); //延时1s
		*/
		Led_Ctrl(LED0_PIN_ROW, LED0_PIN, LED_ON);
		Led_Ctrl(LED1_PIN_ROW, LED0_PIN, LED_OFF);
		delay_ms(DELAY_1S); //延时1s
		Led_Ctrl(LED0_PIN_ROW, LED0_PIN, LED_OFF);
		Led_Ctrl(LED1_PIN_ROW, LED0_PIN, LED_ON);
		delay_ms(DELAY_1S); //延时1s
	}
}

led.h:

#include "stm32f4xx.h"
#include "systick.h"

#ifndef __LED_H
#define __LED_H	 

#define LED0_PIN_ROW GPIOF
#define LED1_PIN_ROW GPIOF

#define LED0_PIN GPIO_PIN_9
#define LED1_PIN GPIO_PIN_10

#define LED_ON  1
#define LED_OFF 2

void LED0_Init(void);//初始化
void LED0_On(void);
void LED0_Off(void);
void Led_Ctrl(GPIO_TypeDef* GPIOx,uint16_t led_pin,uint8_t ctrl);


void delay_init(u8 SYSCLK);
void delay_ms(u16 nms);
void delay_us(u32 nus);

#endif

systick.h:

//摘自正点原子提供例程

#ifndef __SYSTICK_H__
#define __SYSTICK_H__

#include "stm32f4xx.h"

typedef uint32_t  u32;
typedef uint16_t u16;
typedef uint8_t  u8;
static u8  fac_us=0;							//us延时倍乘数			   
static u16 fac_ms=0;							//ms延时倍乘数,在ucos下,代表每个节拍的ms数


void delay_init(u8 SYSCLK);
void delay_us(u32 nus);
void delay_ms(u16 nms);

#endif

systick.c:

#include "systick.h"


//摘自正点原子提供例程
//初始化延迟函数
//当使用OS的时候,此函数会初始化OS的时钟节拍
//SYSTICK的时钟固定为HCLK时钟的1/8
//SYSCLK:系统时钟
void delay_init(u8 SYSCLK)
{
#if SYSTEM_SUPPORT_OS 						//如果需要支持OS.
	u32 reload;
#endif
 	SysTick->CTRL&=~(1<<2);					//SYSTICK使用外部时钟源	 
	fac_us=SYSCLK/8;						//不论是否使用OS,fac_us都需要使用
#if SYSTEM_SUPPORT_OS 						//如果需要支持OS.
	reload=SYSCLK/8;						//每秒钟的计数次数 单位为K	   
	reload*=1000000/delay_ostickspersec;	//根据delay_ostickspersec设定溢出时间
											//reload为24位寄存器,最大值:16777216,在72M下,约合1.86s左右	
	fac_ms=1000/delay_ostickspersec;		//代表OS可以延时的最少单位	   
	SysTick->CTRL|=1<<1;   					//开启SYSTICK中断
	SysTick->LOAD=reload; 					//每1/delay_ostickspersec秒中断一次	
	SysTick->CTRL|=1<<0;   					//开启SYSTICK    
#else
	fac_ms=(u16)fac_us*1000;				//非OS下,代表每个ms需要的systick时钟数   
#endif
}								    
//延时nus
//nus为要延时的us数.		    								   
void delay_us(u32 nus)
{		
	u32 temp;	    	 
	SysTick->LOAD=nus*fac_us; 				//时间加载	  		 
	SysTick->VAL=0x00;        				//清空计数器
	SysTick->CTRL=0x01 ;      				//开始倒数 	 
	do
	{
		temp=SysTick->CTRL;
	}while((temp&0x01)&&!(temp&(1<<16)));	//等待时间到达   
	SysTick->CTRL=0x00;      	 			//关闭计数器
	SysTick->VAL =0X00;       				//清空计数器	 
}
//延时nms
//注意nms的范围
//SysTick->LOAD为24位寄存器,所以,最大延时为:
//nms<=0xffffff*8*1000/SYSCLK
//SYSCLK单位为Hz,nms单位为ms
//对72M条件下,nms<=1864 
void delay_ms(u16 nms)
{	 		  	  
	u32 temp;		   
	SysTick->LOAD=(u32)nms*fac_ms;			//时间加载(SysTick->LOAD为24bit)
	SysTick->VAL =0x00;           			//清空计数器
	SysTick->CTRL=0x01 ;          			//开始倒数  
	do
	{
		temp=SysTick->CTRL;
	}while((temp&0x01)&&!(temp&(1<<16)));	//等待时间到达   
	SysTick->CTRL=0x00;      	 			//关闭计数器
	SysTick->VAL =0X00;       				//清空计数器	  	    
} 

2:通过本节课学习的内客,结合板上蜂呜器的电路,实现一个小型的告警系统,要求蜂鸣器周期性的响2S,停5S。使用CMSIS提供的延时函数。

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

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

相关文章

传染病学模型 | Python实现基于使用受控SIR模型数据平滑对参数估计的影响

效果一览 文章概述 传染病学模型 | Python实现基于使用受控SIR模型数据平滑对参数估计的影响 我们可以采用更多数据驱动的方法,而不是使用移动平均线进行数据平滑。 我们感兴趣的是了解疾病发作和报告疾病日期之间的延迟

九、pig安装

1.上传pig包 2.解压文件 3.改名 4.赋权 5.配置环境变量 export PIG_HOME/usr/local/pig export PATH$PATH:$JAVA_HOME/bin:$HADOOP_HOME/bin:$HADOOP_HOME/sbin:$HIVE_HOME/bin:$HBASE_HOME/bin:$SQOOP_HOME/bin:$PIG_HOME/bin 6.测试

基于SpringBoot+Vue的CSGO赛事管理系统设计与实现(源码+LW+部署文档等)

博主介绍&#xff1a; 大家好&#xff0c;我是一名在Java圈混迹十余年的程序员&#xff0c;精通Java编程语言&#xff0c;同时也熟练掌握微信小程序、Python和Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架…

阿里云瑶池 PolarDB 开源官网焕新升级上线

导读近日&#xff0c;阿里云开源云原生数据库 PolarDB 官方网站全新升级上线。作为 PolarDB 开源项目与开发者、生态伙伴、用户沟通的平台&#xff0c;将以开放、共享、促进交流为宗旨&#xff0c;打造开放多元的环境&#xff0c;以实现共享共赢的目标。 立即体验全新官网&…

c++--二叉树应用

1.根据二叉树创建字符串 力扣 给你二叉树的根节点 root &#xff0c;请你采用前序遍历的方式&#xff0c;将二叉树转化为一个由括号和整数组成的字符串&#xff0c;返回构造出的字符串。 空节点使用一对空括号对 "()" 表示&#xff0c;转化后需要省略所有不影响字符…

web题型

0X01 命令执行 漏洞原理 没有对用户输入的内容进行一定过滤直接传给shell_exec、system一类函数执行 看一个具体例子 cmd1|cmd2:无论cmd1是否执行成功&#xff0c;cmd2将被执行 cmd1;cmd2:无论cmd1是否执行成功&#xff0c;cmd2将被执行 cmd1&cmd2:无论cmd1是否执行成…

AI相机“妙鸭相机”原理分析和手动实现方案

妙鸭相机 一个通过上传大约20张照片&#xff0c;生成专属自拍。在2023年7月末爆火&#xff0c;根据36Kr报道&#xff0c;妙鸭相机系阿里系产品&#xff0c;挂靠在阿里大文娱体系下&#xff0c;并非独立公司。 使用方法是上传20张自拍照片&#xff0c;之后可以选择模板生成自己…

如何创建51单片机KEIL工程

如何创建51单片机KEIL工程步骤&#xff1a; &#xff08;1&#xff09;打开keil软件&#xff0c;点击工具栏-Project&#xff0c;选择创建新的工程&#xff1b; &#xff08;2&#xff09;然后给工程命名&#xff0c;文章以project为例&#xff0c;然后点击保存 &#xff08…

p7付费课程笔记6:CMS GC

目录 前言 工作步骤 缺点 问题 前言 上一章节我们讲了串/并行GC&#xff0c;这一章节说下CMS GC。看前思考一个问题&#xff0c;并行GC与CMS GC的区别在哪里。 什么是CMS收集器 CMS(Concurrent Mark-Sweep)是以牺牲吞吐量为代价来获得最短回收停顿时间的垃圾回收器。对于…

经典CNN(三):DenseNet算法实战与解析

&#x1f368; 本文为&#x1f517;365天深度学习训练营中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊|接辅导、项目定制 1 前言 在计算机视觉领域&#xff0c;卷积神经网络&#xff08;CNN&#xff09;已经成为最主流的方法&#xff0c;比如GoogleNet&#xff0c;…

替换开源LDAP,西井科技用宁盾目录统一身份,为业务敏捷提供支撑

客户介绍 上海西井科技股份有限公司成立于2015年&#xff0c;是一家深耕于大物流领域的人工智能公司&#xff0c;旗下无人驾驶卡车品牌Q-Truck开创了全球全时无人驾驶新能源商用车的先河&#xff0c;迄今为止已为全球16个国家和地区&#xff0c;120余家客户打造智能化升级体验…

前端构建(打包)工具发展史

大多同学的前端学习路线&#xff1a;三件套框架慢慢延伸到其他&#xff0c;在这个过程中&#xff0c;有一个词出现的频率很高&#xff1a;webpack 。 作为一个很出名的前端构建工具我们在网上随便一搜&#xff0c;就会有各种教程&#xff1a;loader plugin entry吧啦吧啦。 但…

【框架篇】Spring MVC 介绍及使用(详细教程)

Spring MVC 介绍 1&#xff0c;MVC 设计模式 MVC&#xff08;Model-View-Controller&#xff09;是一种常见的软件设计模式&#xff0c;用于将应用程序的逻辑分离成三个独立的组件&#xff1a; 模型&#xff08;Model&#xff09;&#xff1a;模型是应用程序的数据和业务逻辑…

C# Blazor 学习笔记(5):blazor文件夹组件引入

文章目录 前言文件夹组件引入文件夹分类文件引入解决方法 前言 为了更好的组件化管理整个文件&#xff0c;我选择使用分文件夹对项目组件进行分类。 文件夹组件引入 文件夹分类 Shared&#xff1a;Layout布局空间放置地方&#xff0c;由于默认创建&#xff0c;动也不好动&a…

Linux —— 进程控制

目录 一&#xff0c;进程创建 写时拷贝 二&#xff0c;进程终止 三&#xff0c;进程等待 获取子进程status 一&#xff0c;进程创建 命令行启动命令&#xff08;程序、指令等&#xff09;&#xff1b;通过程序自身fork创建&#xff1b; #include<unistd.h> //子进程…

【Git】保姆级详解:Git配置SSH Key(密钥和公钥)到github

博主简介&#xff1a;22级计算机科学与技术本科生一枚&#x1f338;博主主页&#xff1a;是瑶瑶子啦每日一言&#x1f33c;: “当人们做不到一些事情的时候&#xff0c;他们会对你说你也同样不能。”——《当幸福来敲门》 克里斯加德纳 Git配置SSH Key 一、什么是Git?二、什么…

Shader 编程:GLSL 重要的内置函数

该原创文章首发于微信公众号&#xff1a;字节流动 未经作者&#xff08;微信ID&#xff1a;Byte-Flow&#xff09;允许&#xff0c;禁止转载 前面发了一些关于 Shader 编程的文章&#xff0c;有读者反馈太碎片化了&#xff0c;希望这里能整理出来一个系列&#xff0c;方便系统的…

二叉树OJ(C)

文章目录 1.单值二叉树1.1法一&#xff1a;无返回值1.2法二&#xff1a;有返回值 2.相同的树3.对称二叉树4.二叉树的前序遍历5.二叉树的中序遍历6.二叉树的后序遍历7.另一棵树的子树8.二叉树遍历 1.单值二叉树 1.1法一&#xff1a;无返回值 struct TreeNode {int val;struct …

docker端口映射详解(随机端口、指定IP端口、随意ip指定端口、指定ip随机端口)

目录 docker端口映射详解 一、端口映射概述&#xff1a; 二、案例实验&#xff1a; 1、-P选项&#xff0c;随机端口 2、使用-p可以指定要映射到的本地端口。 Local_Port:Container_Port&#xff0c;任意地址的指定端口 Local_IP:Local_Port:Container_Port 映射到指定地…

Java设计模式之工厂设计模式

简介 工厂模式是一种常见的设计模式&#xff0c;用于创建对象的过程中&#xff0c;通过工厂类来封装对象的创建过程。其核心思想是将对象的创建和使用分离&#xff0c;从而降低耦合度&#xff0c;提高代码的可维护性和可扩展性。工厂模式通常包括三种类型&#xff1a;简单工厂…