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

小华HC32F448串口使用

目录

1. 串口GPIO配置

2. 串口波特率配置

3. 串口接收超时配置

4. 串口中断注册

5. 串口初始化

6. 串口数据接收处理

7. DMA接收配置和处理


1. 串口GPIO配置

端口号和Pin脚号跟STM32没什么区别。

串口复用功能跟STM32大不一样。

如下图,选自HC32F448 表 2-1 引脚功能表。

1)每个管脚都有对应的管脚名称、中断号,以及功能号

2)调试口默认为TRACE/JTAG功能号,若要使能普通GPIO功能则要关闭调试功能

3)非调试口默认功能号为Func0,即普通GPIO功能。Func2到Func11为定时器或时钟功能,Func12为EXMC/TIMA功能

4)Func32~63为通用复用功能-分为两组,对于同一组的IO,可以配置为UART/I2C/SPI/CAN 4组功能,且Rx/Tx可以互换。而不是像STM32那样,每个IO的复用功能是固定的,对应通讯线必须一一选对。

如下,硬件选择了PB0和PA7作为串口通讯脚,可以在FG1任意选择一个可用串口使用。

#define USART_RX_PORT                   (GPIO_PORT_B)   /* PB0: USART2_RX */
#define USART_RX_PIN                    (GPIO_PIN_00)
#define USART_RX_GPIO_FUNC              (GPIO_FUNC_37)
#define USART_TX_PORT                   (GPIO_PORT_A)   /* PA7: USART2_TX */
#define USART_TX_PIN                    (GPIO_PIN_07)
#define USART_TX_GPIO_FUNC              (GPIO_FUNC_36)static void UartGpioConfig(void)
{GPIO_SetFunc(USART_RX_PORT, USART_RX_PIN, USART_RX_GPIO_FUNC);GPIO_SetFunc(USART_TX_PORT, USART_TX_PIN, USART_TX_GPIO_FUNC);
}

2. 串口波特率配置

static void UartBaudConfig(void)
{USART_FCG_ENABLE();stc_usart_uart_init_t stcUartInit;(void)USART_UART_StructInit(&stcUartInit);stcUartInit.u32ClockDiv = USART_CLK_DIV64;stcUartInit.u32CKOutput = USART_CK_OUTPUT_ENABLE;stcUartInit.u32Baudrate = USART_BAUDRATE;stcUartInit.u32OverSampleBit = USART_OVER_SAMPLE_8BIT;USART_UART_Init(USART_UNIT, &stcUartInit, NULL);
}

3. 串口接收超时配置

小华HC32F4串口支持的中断与STM32大有不同:

1)HC32 接收数据寄存器满中断,在收到1个字节时就会触发。等同于STM32的RXNE。名字不同

2)HC32 TIMEOUT中断,等同于STM32的空闲中断 IDLE 。HC32通过关联定时器直接配置超时时间,比STM32更加简便。

定时器Timer0被专门用来做串口的计时器,板子用的串口2,所以定时器要配置Timer0_1 B 。

//串口接收超时设置·关联定时器
#define USART_TIMEOUT_BITS              (5000U)
#define TMR0_UNIT                       (CM_TMR0_1)
#define TMR0_CH                         (TMR0_CH_B)
#define TMR0_FCG_ENABLE()               (FCG_Fcg2PeriphClockCmd(FCG2_PERIPH_TMR0_1, ENABLE))/** TMR0_Config()* 配置串口接收超时
*/
static void TMR0_Config(void)
{uint16_t u16Div;uint16_t u16Delay;uint16_t u16CompareValue;stc_tmr0_init_t stcTmr0Init;TMR0_FCG_ENABLE();/* Initialize TMR0 base function. */stcTmr0Init.u32ClockSrc = TMR0_CLK_SRC_XTAL32;stcTmr0Init.u32ClockDiv = TMR0_CLK_DIV8;stcTmr0Init.u32Func     = TMR0_FUNC_CMP;if (TMR0_CLK_DIV1 == stcTmr0Init.u32ClockDiv) {u16Delay = 7U;} else if (TMR0_CLK_DIV2 == stcTmr0Init.u32ClockDiv) {u16Delay = 5U;} else if ((TMR0_CLK_DIV4 == stcTmr0Init.u32ClockDiv) || \(TMR0_CLK_DIV8 == stcTmr0Init.u32ClockDiv) || \(TMR0_CLK_DIV16 == stcTmr0Init.u32ClockDiv)) {u16Delay = 3U;} else {u16Delay = 2U;}u16Div = (uint16_t)1U << (stcTmr0Init.u32ClockDiv >> TMR0_BCONR_CKDIVA_POS);u16CompareValue = ((USART_TIMEOUT_BITS + u16Div - 1U) / u16Div) - u16Delay;stcTmr0Init.u16CompareValue = u16CompareValue;(void)TMR0_Init(TMR0_UNIT, TMR0_CH, &stcTmr0Init);TMR0_HWStartCondCmd(TMR0_UNIT, TMR0_CH, ENABLE);TMR0_HWClearCondCmd(TMR0_UNIT, TMR0_CH, ENABLE);
}

4. 串口中断注册

#define USART_RX_ERR_IRQn               (INT005_IRQn)
#define USART_RX_ERR_INT_SRC            (INT_SRC_USART2_EI)
#define USART_RX_FULL_IRQn              (INT006_IRQn)
#define USART_RX_FULL_INT_SRC           (INT_SRC_USART2_RI)
#define USART1_RX_TIMEOUT_IRQn          (INT007_IRQn)
#define USART1_RX_TIMEOUT_INT_SRC       (INT_SRC_USART2_RTO)static void USART_RxFull_IrqCallback(void);
static void USART_RxError_IrqCallback(void);
static void USART_RxTimeout_IrqCallback(void);static void RegisterIrq(void)
{stc_irq_signin_config_t stcIrqSigninConfig;/* Register RX full IRQ handler. */stcIrqSigninConfig.enIRQn = USART_RX_FULL_IRQn;stcIrqSigninConfig.enIntSrc = USART_RX_FULL_INT_SRC;stcIrqSigninConfig.pfnCallback = &USART_RxFull_IrqCallback;(void)INTC_IrqSignIn(&stcIrqSigninConfig);NVIC_ClearPendingIRQ(stcIrqSigninConfig.enIRQn);NVIC_SetPriority(stcIrqSigninConfig.enIRQn, DDL_IRQ_PRIO_DEFAULT);NVIC_EnableIRQ(stcIrqSigninConfig.enIRQn);/* Register RX error IRQ handler. */stcIrqSigninConfig.enIRQn = USART_RX_ERR_IRQn;stcIrqSigninConfig.enIntSrc = USART_RX_ERR_INT_SRC;stcIrqSigninConfig.pfnCallback = &USART_RxError_IrqCallback;(void)INTC_IrqSignIn(&stcIrqSigninConfig);NVIC_ClearPendingIRQ(stcIrqSigninConfig.enIRQn);NVIC_SetPriority(stcIrqSigninConfig.enIRQn, DDL_IRQ_PRIO_DEFAULT);NVIC_EnableIRQ(stcIrqSigninConfig.enIRQn);/* Register RX timeout IRQ handler. */stcIrqSigninConfig.enIRQn = USART1_RX_TIMEOUT_IRQn;stcIrqSigninConfig.enIntSrc = USART1_RX_TIMEOUT_INT_SRC;stcIrqSigninConfig.pfnCallback = &USART_RxTimeout_IrqCallback;(void)INTC_IrqSignIn(&stcIrqSigninConfig);NVIC_ClearPendingIRQ(stcIrqSigninConfig.enIRQn);NVIC_SetPriority(stcIrqSigninConfig.enIRQn, DDL_IRQ_PRIO_DEFAULT);NVIC_EnableIRQ(stcIrqSigninConfig.enIRQn);
}

5. 串口初始化

LL_PERIPH_WE() 为打开相应寄存器的写使能

LL_PERIPH_WP() 为关闭相应寄存器的写使能

void UART_Init(void)
{LL_PERIPH_WE(LL_PERIPH_ALL);UartGpioConfig();UartBaudConfig();TMR0_Config();RegisterIrq();LL_PERIPH_WP(LL_PERIPH_ALL);USART_FuncCmd(USART_UNIT, ( USART_TX | USART_RX | USART_INT_RX | USART_RX_TIMEOUT | USART_INT_RX_TIMEOUT), ENABLE);
}

6. 串口数据接收处理

USART_RxFull_IrqCallback 中断 只负责接收和缓存单字节数据,以及递增数据长度 (通过读数据清除标志位)

USART_RxTimeout_IrqCallback 中断 处理超时中断(超时中断触发后必须要关闭定时器,和清除标志位)

USART_RxError_IrqCallback 中断 处理异常错误

static void USART_RxFull_IrqCallback(void)
{uint8_t u8Data = (uint8_t)USART_ReadData(USART_UNIT);if(gps_len < RX_FRAME_LEN_MAX)gps_buf[gps_len++] = u8Data;
}static void USART_RxError_IrqCallback(void)
{(void)USART_ReadData(USART_UNIT);USART_ClearStatus(USART_UNIT, (USART_FLAG_PARITY_ERR | USART_FLAG_FRAME_ERR | USART_FLAG_OVERRUN));
}static void USART_RxTimeout_IrqCallback(void)
{TMR0_Stop(TMR0_UNIT, TMR0_CH);USART_ClearStatus(USART_UNIT, USART_FLAG_RX_TIMEOUT);GpsRxCallBack(gps_buf, gps_len);gps_len = 0;
}

对于GPS、Wifi这类不频繁的数据交互,用到超时中断和接收寄存器满就可以处理数据了。

对于4G/蓝牙等有持续大量数据交互的模块,就需要用到DMA了。

7. 串口数据发送

static int32_t UartSendByte(CM_USART_TypeDef *UART, uint8_t ch)
{uint32_t u32TxEmpty = 0UL;__IO uint32_t u32TmpCount = 0UL;uint32_t u32Timeout = HCLK_VALUE/USART_BAUDRATE;int32_t i32Ret = LL_ERR_INVD_PARAM;/* Wait TX data register empty */while ((u32TmpCount <= u32Timeout) && (0UL == u32TxEmpty)) {u32TxEmpty = READ_REG32_BIT(UART->SR, USART_SR_TXE);u32TmpCount++;}if (0UL != u32TxEmpty) {WRITE_REG16(UART->TDR, ch);i32Ret = LL_OK;} else {i32Ret = LL_ERR_TIMEOUT;}return i32Ret;
}

8. DMA接收配置和处理

DMA配置方式与STM32基本相同:

1)设置DMA源地址和源地址增长类型,设置目的地址和目的地址增长类型

DMA接收属于串口数据寄存器到内存,即源地址固定,目的地址递增

DMA发送属于内存到串口数据寄存器,即源地址递增,目的地址固定

2)设置位宽、传输大小、传输块数


所不同的是,HC32有一个可配置的自动运行系统AOS。

可以配置AOS源和AOS目标.

AOS源可以是DMA传输完成、UART接收数据、定时器上溢和下溢、event电平变化等等。

AOS目标可以是DMA传输、定时器计数、ADC模数转换、event事件等等

如下是DMA初始化配置的参考代码,配置了串口DMA接收和串口DMA发送:

//DMA单元
#define RX_DMA_UNIT                     (CM_DMA1)
//DMA通道号·通道号越小优先级越高
#define RX_DMA_CH                       (DMA_CH0)
//DMA单元时钟
#define RX_DMA_FCG_ENABLE()             (FCG_Fcg0PeriphClockCmd(FCG0_PERIPH_DMA1, ENABLE))
//AOS系统的目标·触发DMA1通道0传输
#define RX_DMA_TRIG_SEL                 (AOS_DMA1_0)
//AOS系统的触发源·接收数据寄存器满中断
#define RX_DMA_TRIG_EVT_SRC             (EVT_SRC_USART1_RI)
//AOS系统的目标·DMA完成中断
#define RX_DMA_RECONF_TRIG_SEL          (AOS_DMA_RC)
//AOS系统的触发源·AOS_STRG中断源
#define RX_DMA_RECONF_TRIG_EVT_SRC      (EVT_SRC_AOS_STRG)
//DMA传输完成中断·通道号1
#define RX_DMA_TC_INT                   (DMA_INT_TC_CH0)
//DMA传输完成标志·通道号2
#define RX_DMA_TC_FLAG                  (DMA_FLAG_TC_CH0)
//DMA传输完成中断号
#define RX_DMA_TC_IRQn                  (INT000_IRQn)
//DMA传输完成中断源
#define RX_DMA_TC_INT_SRC               (INT_SRC_DMA1_TC0)//串口DMA发送配置
#define TX_DMA_UNIT                     (CM_DMA2)
#define TX_DMA_CH                       (DMA_CH0)
#define TX_DMA_FCG_ENABLE()             (FCG_Fcg0PeriphClockCmd(FCG0_PERIPH_DMA2, ENABLE))
#define TX_DMA_TRIG_SEL                 (AOS_DMA2_0)
#define TX_DMA_TRIG_EVT_SRC             (EVT_SRC_USART1_TI)
#define TX_DMA_TC_INT                   (DMA_INT_TC_CH0)
#define TX_DMA_TC_FLAG                  (DMA_FLAG_TC_CH0)
#define TX_DMA_TC_IRQn                  (INT001_IRQn)
#define TX_DMA_TC_INT_SRC               (INT_SRC_DMA2_TC0)/******************************************************************************** Local variable definitions ('static')******************************************************************************/
static __IO en_flag_status_t m_enTxEnd = SET;
static uint8_t m_4gRxBuf[RX_FRAME_LEN_MAX];
static uint8_t *m_auTxBuf = NULL;/******************************************************************************** Local function definitions ('static')******************************************************************************/
static void RX_DMA_TC_IrqCallback(void);
static void TX_DMA_TC_IrqCallback(void);/** DMA_Config()* 配置串口DMA接收和DMA发送
*/
static int32_t DMA_Config(void)
{int32_t i32Ret;stc_dma_init_t stcDmaInit;stc_dma_llp_init_t stcDmaLlpInit;stc_irq_signin_config_t stcIrqSignConfig;static stc_dma_llp_descriptor_t stcLlpDesc;//使能DMA和FCG时钟RX_DMA_FCG_ENABLE();TX_DMA_FCG_ENABLE();FCG_Fcg0PeriphClockCmd(FCG0_PERIPH_AOS, ENABLE);/* USART_RX_DMA */(void)DMA_StructInit(&stcDmaInit);stcDmaInit.u32IntEn = DMA_INT_ENABLE;//DMA interrupt enablestcDmaInit.u32BlockSize = 1UL;//DMA block sizestcDmaInit.u32TransCount = ARRAY_SZ(m_4gRxBuf);//DMAbuf大小stcDmaInit.u32DataWidth = DMA_DATAWIDTH_8BIT;//DMAbuf位宽stcDmaInit.u32DestAddr = (uint32_t)m_4gRxBuf;//DMAbuf地址stcDmaInit.u32SrcAddr = (uint32_t)(&USART_UNIT->RDR);//由外设到内存的 外设地址 -> 串口数据寄存器stcDmaInit.u32SrcAddrInc = DMA_SRC_ADDR_FIX;//由外设到内存的 源地址模式 固定stcDmaInit.u32DestAddrInc = DMA_DEST_ADDR_INC;//由外设到内存的 目标地址模式 自动递增i32Ret = DMA_Init(RX_DMA_UNIT, RX_DMA_CH, &stcDmaInit);if (LL_OK == i32Ret) {(void)DMA_LlpStructInit(&stcDmaLlpInit);stcDmaLlpInit.u32State = DMA_LLP_ENABLE;stcDmaLlpInit.u32Mode  = DMA_LLP_WAIT;stcDmaLlpInit.u32Addr  = (uint32_t)&stcLlpDesc;(void)DMA_LlpInit(RX_DMA_UNIT, RX_DMA_CH, &stcDmaLlpInit);//初始化DMA链表指针stcLlpDesc.SARx   = stcDmaInit.u32SrcAddr;stcLlpDesc.DARx   = stcDmaInit.u32DestAddr;stcLlpDesc.DTCTLx = (stcDmaInit.u32TransCount << DMA_DTCTL_CNT_POS) | (stcDmaInit.u32BlockSize << DMA_DTCTL_BLKSIZE_POS);;stcLlpDesc.LLPx   = (uint32_t)&stcLlpDesc;stcLlpDesc.CHCTLx = stcDmaInit.u32SrcAddrInc | stcDmaInit.u32DestAddrInc | stcDmaInit.u32DataWidth |  \stcDmaInit.u32IntEn      | stcDmaLlpInit.u32State    | stcDmaLlpInit.u32Mode;DMA_ReconfigLlpCmd(RX_DMA_UNIT, RX_DMA_CH, ENABLE);DMA_ReconfigCmd(RX_DMA_UNIT, ENABLE);AOS_SetTriggerEventSrc(RX_DMA_RECONF_TRIG_SEL, RX_DMA_RECONF_TRIG_EVT_SRC);stcIrqSignConfig.enIntSrc = RX_DMA_TC_INT_SRC;stcIrqSignConfig.enIRQn  = RX_DMA_TC_IRQn;stcIrqSignConfig.pfnCallback = &RX_DMA_TC_IrqCallback;(void)INTC_IrqSignIn(&stcIrqSignConfig);NVIC_ClearPendingIRQ(stcIrqSignConfig.enIRQn);NVIC_SetPriority(stcIrqSignConfig.enIRQn, DDL_IRQ_PRIO_DEFAULT);NVIC_EnableIRQ(stcIrqSignConfig.enIRQn);AOS_SetTriggerEventSrc(RX_DMA_TRIG_SEL, RX_DMA_TRIG_EVT_SRC);DMA_Cmd(RX_DMA_UNIT, ENABLE);DMA_TransCompleteIntCmd(RX_DMA_UNIT, RX_DMA_TC_INT, ENABLE);(void)DMA_ChCmd(RX_DMA_UNIT, RX_DMA_CH, ENABLE);}(void)DMA_StructInit(&stcDmaInit);stcDmaInit.u32IntEn = DMA_INT_ENABLE;stcDmaInit.u32BlockSize = 1UL;stcDmaInit.u32TransCount = ARRAY_SZ(m_4gRxBuf);stcDmaInit.u32DataWidth = DMA_DATAWIDTH_8BIT;stcDmaInit.u32DestAddr = (uint32_t)(&USART_UNIT->TDR);stcDmaInit.u32SrcAddr = (uint32_t)m_4gRxBuf;stcDmaInit.u32SrcAddrInc = DMA_SRC_ADDR_INC;stcDmaInit.u32DestAddrInc = DMA_DEST_ADDR_FIX;i32Ret = DMA_Init(TX_DMA_UNIT, TX_DMA_CH, &stcDmaInit);if (LL_OK == i32Ret){stcIrqSignConfig.enIntSrc = TX_DMA_TC_INT_SRC;stcIrqSignConfig.enIRQn  = TX_DMA_TC_IRQn;stcIrqSignConfig.pfnCallback = &TX_DMA_TC_IrqCallback;(void)INTC_IrqSignIn(&stcIrqSignConfig);NVIC_ClearPendingIRQ(stcIrqSignConfig.enIRQn);NVIC_SetPriority(stcIrqSignConfig.enIRQn, DDL_IRQ_PRIO_DEFAULT);NVIC_EnableIRQ(stcIrqSignConfig.enIRQn);AOS_SetTriggerEventSrc(TX_DMA_TRIG_SEL, TX_DMA_TRIG_EVT_SRC);DMA_Cmd(TX_DMA_UNIT, ENABLE);DMA_TransCompleteIntCmd(TX_DMA_UNIT, TX_DMA_TC_INT, ENABLE);}return i32Ret;
}

如下是DMA接收处理代码:

1)USART_RxTimeout_IrqCallback

重启AOS系统

关闭串口超时定时器,清除串口超时标志位。

处理DMA接收数据。

2)RX_DMA_TC_IrqCallback

即接收完成中断

硬件上需要清除中断标志位

3)USART_TxComplete_IrqCallback

即串口发送完成中断

硬件上需要清除标志位,一般要失能发送中断

//串口接收超时中断
static void USART_RxTimeout_IrqCallback(void)
{uint16_t unLen = RX_FRAME_LEN_MAX - (uint16_t)DMA_GetTransCount(RX_DMA_UNIT, RX_DMA_CH);AOS_SW_Trigger();TMR0_Stop(TMR0_UNIT, TMR0_CH);USART_ClearStatus(USART_UNIT, USART_FLAG_RX_TIMEOUT);if(unLen != 0 && unLen != RX_FRAME_LEN_MAX)DtuRxCallBack(m_4gRxBuf, unLen);
}//串口DMA接收·传输完成中断
static void RX_DMA_TC_IrqCallback(void)
{DtuRxCallBack(m_4gRxBuf, RX_FRAME_LEN_MAX);DMA_ClearTransCompleteStatus(RX_DMA_UNIT, RX_DMA_TC_FLAG);
}//串口发送完成中断
static void USART_TxComplete_IrqCallback(void)
{m_enTxEnd = SET;DtuTxCallBack(m_auTxBuf);USART_FuncCmd(USART_UNIT, (USART_TX | USART_INT_TX_CPLT), DISABLE);USART_ClearStatus(USART_UNIT, USART_FLAG_TX_CPLT);
}//串口接收错误中断
static void USART_RxError_IrqCallback(void)
{(void)USART_ReadData(USART_UNIT);USART_ClearStatus(USART_UNIT, (USART_FLAG_PARITY_ERR | USART_FLAG_FRAME_ERR | USART_FLAG_OVERRUN));
}//串口DMA发送·传输完成中断
static void TX_DMA_TC_IrqCallback(void)
{USART_FuncCmd(USART_UNIT, USART_INT_TX_CPLT, ENABLE);DMA_ClearTransCompleteStatus(TX_DMA_UNIT, TX_DMA_TC_FLAG);
}

9. DMA发送

//串口DMA发送
void DtuDMASend(uint8_t *pBuf, uint16_t u16TxLen)
{
#if 0 //串口发送数据打印printf("Tx: ");for(uint16_t i = 0; i < u16TxLen; i++){printf("%02X",pBuf[i]);}printf("\r\n");
#endif//等待上一包发完while(m_enTxEnd == RESET);m_enTxEnd = RESET;m_auTxBuf = pBuf;//启动DMA传输DMA_SetSrcAddr(TX_DMA_UNIT, TX_DMA_CH, (uint32_t)pBuf);DMA_SetTransCount(TX_DMA_UNIT, TX_DMA_CH, u16TxLen);(void)DMA_ChCmd(TX_DMA_UNIT, TX_DMA_CH, ENABLE);USART_FuncCmd(USART_UNIT, USART_TX, ENABLE);
}

相关文章:

小华HC32F448串口使用

目录 1. 串口GPIO配置 2. 串口波特率配置 3. 串口接收超时配置 4. 串口中断注册 5. 串口初始化 6. 串口数据接收处理 7. DMA接收配置和处理 1. 串口GPIO配置 端口号和Pin脚号跟STM32没什么区别。 串口复用功能跟STM32大不一样。 如下图&#xff0c;选自HC32F448 表 2…...

Redis实现简易消息队列的三种方式

Redis实现简易消息队列的三种方式 消息队列简介 消息队列是一种用于在计算机系统中传递和处理数据的重要工具。如果你完全不了解消息队列&#xff0c;不用担心&#xff0c;我将尽力以简单明了的方式来解释它。 首先&#xff0c;想象一下你正在玩一个游戏&#xff0c;而游戏中…...

基于SpringBoot的在线小说阅读平台系统

基于SpringBoot的在线小说阅读平台系统的设计与实现~ 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringBootMyBatisVue工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 系统展示 主页 个人中心 登录界面 管理员界面 摘要 基于Spring Boot的在线小说阅读…...

VMware Workstation 与 Hyper-V 不兼容。请先从系统中移除 Hyper-V 角色

引用地址...

uniapp h5 MD5加密

文章目录 1.当使用 CryptoJS 进行 MD5 加密时&#xff0c;你需要先引入 CryptoJS 库并确保它已经正确安装。下面是一个更详细的示例代码&#xff1a;2.然后&#xff0c;在需要使用 MD5 加密的地方&#xff0c;引入 CryptoJS 代码库&#xff1a;3.接下来&#xff0c;我们定义一个…...

2023_Spark_实验十八:安装FinalShell

下载安装包 链接&#xff1a;https://pan.baidu.com/s/14cOJDcezzuwUYowPsOA-sg?pwd6htc 提取码&#xff1a;6htc 下载文件名称&#xff1a;FinalShell.zip 二、安装 三、启动FinalShell 四、连接远程 linux 服务器 先确保linux系统已经开启&#xff0c;不然连接不上 左边…...

文件服务器管理服务器怎么设置

文件服务器是一种提供文件存储和共享服务的服务器&#xff0c;它可以方便企业内部的员工共享文件&#xff0c;提高工作效率。为了更好地管理和维护文件服务器&#xff0c;需要对其进行合理的设置。下面小编将介绍文件服务器管理服务器的基本设置方法。 一、选择合适的操作系统 …...

LeetCode每日一题——Single Number

文章目录 一、题目二、题解 一、题目 136. Single Number Given a non-empty array of integers nums, every element appears twice except for one. Find that single one. You must implement a solution with a linear runtime complexity and use only constant extra …...

有什么手机软件能分离人声和音乐?

很多人在制作混剪视频&#xff0c;需要二次创作的时候&#xff0c;就经常会把人声分离、背景音乐伴奏提取出来&#xff0c;然后重新加入自己的创意跟想法。下面就一起来看看如何用手机软件分离人声和音乐的吧&#xff01; 音分轨 一款可以分离人声和背景音乐的手机软件&#x…...

私人服务器可以干嘛

目录 搭建个人网站或博客&#xff1a; 远程桌面&#xff1a; 作为网盘储存&#xff1a; 作为测试和学习环境&#xff1a; 推广产品&#xff1a; 游戏私服(注意,仅限于个人自己单机玩)&#xff1a; 个人服务器可以用于多种用途&#xff0c;以下是一些常见的用途&#xff1a;…...

【EI会议征稿】第三届高性能计算与通信工程国际学术会议(HPCCE 2023)

第三届高性能计算与通信工程国际学术会议(HPCCE 2023) 第三届高性能计算与通信工程国际学术会议&#xff08;HPCCE 2023&#xff09;将于2023年12月22-24日在长沙召开。HPCCE 2023将围绕“高性能计算与通信工程”的最新研究领域&#xff0c;为来自国内外高等院校、科学研究所、…...

项目管理,如何做到流程标准化?

在PMP管理学习规范化、标准化和流程化的背景下&#xff0c;我们在日常工作中会遇到各种大小不一的工作项目。为了能够确保项目按时高质量地完成&#xff0c;项目管理变得至关重要。项目管理可以简单地解释为&#xff0c;在给定的时间和资源限制下&#xff0c;通过协调有限资源&…...

windows编译ollvm笔记

准备工作 1.找到Android SDK目录配置好cmake环境变量 E:\AndroidSDK\cmake\3.18.1&#xff08;E:\AndroidSDK为 Android SDK目录地址&#xff09;。 下载llvm-mingw编译环境(gcc编译器的windows版本&#xff0c;即可以在windows平台上使用gcc编译器)&#xff0c;下载地址&…...

问:TCP/IP协议栈在内核态的好还是用户态的好

“TCP/IP协议栈到底是内核态的好还是用户态的好&#xff1f;” 问题的根源在于&#xff0c;干嘛非要这么刻意地去区分什么内核态和用户态。 引子 为了不让本文成为干巴巴的说教&#xff0c;在文章开头&#xff0c;我以一个实例分析开始。 最近一段时间&#xff0c;我几乎每…...

JavaScript-Vue基础语法-创建-组件-路由

文章目录 1.创建vue项目1.1.自定义创建项目1.2.项目结构解析1.3.主要文件1.4.其它 2.项目运行3.Vue组件概念3.1.组件基础概念3.2.单文件组件三要素3.3.组件注册3.4.组件通信 4.Vue路由概念4.1.简单使用4.2.路由参数4.3.嵌套路由4.4.路由导航4.5.代码导航4.6.路由守卫 5.总结 HT…...

前端开发中的 TypeScript 泛型:深入解析

前端开发中的 TypeScript 泛型&#xff1a;深入解析 TypeScript&#xff08;简称 TS&#xff09;是一种由微软开发的强类型超集 JavaScript 语言&#xff0c;它为前端开发者提供了更严格的类型检查和更强大的工具支持。其中&#xff0c;泛型是 TypeScript 中的一个强大概念&am…...

06-spring的beanFactoryPostProcessor的执行

文章目录 1. 接口BeanFactoryPostProcessor1.1 英文说明及要点2. BeanDefinitionRegistryPostProcessor3. 执行逻辑4. 几个重要实现类1. 接口BeanFactoryPostProcessor 1.1 英文说明及要点 Factory hook that allows for custom modification of an application context’s b…...

想要精通算法和SQL的成长之路 - 分割数组的最大值

想要精通算法和SQL的成长之路 - 分割数组的最大值 前言一. 分割数组的最大值1.1 二分法 前言 想要精通算法和SQL的成长之路 - 系列导航 一. 分割数组的最大值 原题链接 首先面对这个题目&#xff0c;我们可以捕获几个关键词&#xff1a; 非负整数。非空连续子数组。 那么我…...

【深度学习】【Opencv】【GPU】python/C++调用onnx模型【基础】

【深度学习】【Opencv】【GPU】python/C调用onnx模型【基础】 提示:博主取舍了很多大佬的博文并亲测有效,分享笔记邀大家共同学习讨论 文章目录 【深度学习】【Opencv】【GPU】python/C调用onnx模型【基础】前言Python版本OpenCVWindows平台安装OpenCVopencv调用onnx模型 C版本…...

Oracle update 关联更新优化方法

关联更新顾名思义就是指&#xff0c;更新的数据从关联的表中获取并update到目标表。并且该SQL将会是一个天然的嵌套循环。有两种优化思路解决&#xff1a; 1、PLSQL 根据rowid更新 是否需要加order by rowid的考量&#xff1a; 如果buffer cache足够大&#xff0c;能够放得下要…...

在软件开发中正确使用MySQL日期时间类型的深度解析

在日常软件开发场景中&#xff0c;时间信息的存储是底层且核心的需求。从金融交易的精确记账时间、用户操作的行为日志&#xff0c;到供应链系统的物流节点时间戳&#xff0c;时间数据的准确性直接决定业务逻辑的可靠性。MySQL作为主流关系型数据库&#xff0c;其日期时间类型的…...

黑马Mybatis

Mybatis 表现层&#xff1a;页面展示 业务层&#xff1a;逻辑处理 持久层&#xff1a;持久数据化保存 在这里插入图片描述 Mybatis快速入门 ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/6501c2109c4442118ceb6014725e48e4.png //logback.xml <?xml ver…...

Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例

使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件&#xff0c;常用于在两个集合之间进行数据转移&#xff0c;如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model&#xff1a;绑定右侧列表的值&…...

剑指offer20_链表中环的入口节点

链表中环的入口节点 给定一个链表&#xff0c;若其中包含环&#xff0c;则输出环的入口节点。 若其中不包含环&#xff0c;则输出null。 数据范围 节点 val 值取值范围 [ 1 , 1000 ] [1,1000] [1,1000]。 节点 val 值各不相同。 链表长度 [ 0 , 500 ] [0,500] [0,500]。 …...

Python爬虫(二):爬虫完整流程

爬虫完整流程详解&#xff08;7大核心步骤实战技巧&#xff09; 一、爬虫完整工作流程 以下是爬虫开发的完整流程&#xff0c;我将结合具体技术点和实战经验展开说明&#xff1a; 1. 目标分析与前期准备 网站技术分析&#xff1a; 使用浏览器开发者工具&#xff08;F12&…...

GO协程(Goroutine)问题总结

在使用Go语言来编写代码时&#xff0c;遇到的一些问题总结一下 [参考文档]&#xff1a;https://www.topgoer.com/%E5%B9%B6%E5%8F%91%E7%BC%96%E7%A8%8B/goroutine.html 1. main()函数默认的Goroutine 场景再现&#xff1a; 今天在看到这个教程的时候&#xff0c;在自己的电…...

(一)单例模式

一、前言 单例模式属于六大创建型模式,即在软件设计过程中,主要关注创建对象的结果,并不关心创建对象的过程及细节。创建型设计模式将类对象的实例化过程进行抽象化接口设计,从而隐藏了类对象的实例是如何被创建的,封装了软件系统使用的具体对象类型。 六大创建型模式包括…...

macOS 终端智能代理检测

&#x1f9e0; 终端智能代理检测&#xff1a;自动判断是否需要设置代理访问 GitHub 在开发中&#xff0c;使用 GitHub 是非常常见的需求。但有时候我们会发现某些命令失败、插件无法更新&#xff0c;例如&#xff1a; fatal: unable to access https://github.com/ohmyzsh/oh…...

[USACO23FEB] Bakery S

题目描述 Bessie 开了一家面包店! 在她的面包店里&#xff0c;Bessie 有一个烤箱&#xff0c;可以在 t C t_C tC​ 的时间内生产一块饼干或在 t M t_M tM​ 单位时间内生产一块松糕。 ( 1 ≤ t C , t M ≤ 10 9 ) (1 \le t_C,t_M \le 10^9) (1≤tC​,tM​≤109)。由于空间…...

echarts使用graphic强行给图增加一个边框(边框根据自己的图形大小设置)- 适用于无法使用dom的样式

pdf-lib https://blog.csdn.net/Shi_haoliu/article/details/148157624?spm1001.2014.3001.5501 为了完成在pdf中导出echarts图&#xff0c;如果边框加在dom上面&#xff0c;pdf-lib导出svg的时候并不会导出边框&#xff0c;所以只能在echarts图上面加边框 grid的边框是在图里…...