stm32標準庫usart1,usrat2,usart3三個串口的配置以及printf重定向(串口輸出)

? ? ? ? 我剛開始學串口時,因為要用到多個串口,自己又懶得改,總是在網上要找半天。下面將stm32的三個串口配置羅列下來,方便大家直接copy。

1、串口1

引腳:TX:PA9;

???????????RX:PA10;

重定向函數:printf();

usart.c

#include "sys.h"
#include "usart.h"	  
// 	 
//如果使用ucos,則包括下面的頭文件即可.
#if SYSTEM_SUPPORT_OS
#include "includes.h"					//ucos 使用	  
#endif//
//加入以下代碼,支持printf函數,而不需要選擇use MicroLIB	  
#if 1
#pragma import(__use_no_semihosting)             
//標準庫需要的支持函數                 
struct __FILE 
{ int handle; }; FILE __stdout;       
//定義_sys_exit()以避免使用半主機模式    
void _sys_exit(int x) 
{ x = x; 
} 
//重定義fputc函數 
int fputc(int ch, FILE *f)
{      while((USART2->SR&0X40)==0);//循環發送,直到發送完畢   USART2->DR = (u8) ch;      return ch;
}
#endif #if EN_USART1_RX   //如果使能了接收
//串口1中斷服務程序
//注意,讀取USARTx->SR能避免莫名其妙的錯誤   	
u8 USART_RX_BUF[USART_REC_LEN];     //接收緩沖,最大USART_REC_LEN個字節.
//接收狀態
//bit15,	接收完成標志
//bit14,	接收到0x0d
//bit13~0,	接收到的有效字節數目
u16 USART_RX_STA=0;       //接收狀態標記	  void uart1_init(u32 bound){//GPIO端口設置GPIO_InitTypeDef GPIO_InitStructure;USART_InitTypeDef USART_InitStructure;NVIC_InitTypeDef NVIC_InitStructure;RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1|RCC_APB2Periph_GPIOA, ENABLE);	//使能USART1,GPIOA時鐘//USART1_TX   GPIOA.9GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; //PA.9GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;	//復用推挽輸出GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化GPIOA.9//USART1_RX	  GPIOA.10初始化GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;//PA10GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;//浮空輸入GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化GPIOA.10  //Usart1 NVIC 配置NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3 ;//搶占優先級3NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;		//子優先級3NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;			//IRQ通道使能NVIC_Init(&NVIC_InitStructure);	//根據指定的參數初始化VIC寄存器//USART 初始化設置USART_InitStructure.USART_BaudRate = bound;//串口波特率USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字長為8位數據格式USART_InitStructure.USART_StopBits = USART_StopBits_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); //初始化串口1USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//開啟串口接受中斷USART_Cmd(USART1, ENABLE);                    //使能串口1 }void USART1_IRQHandler(void)                	//串口1中斷服務程序
{u8 Res;
#if SYSTEM_SUPPORT_OS 		//如果SYSTEM_SUPPORT_OS為真,則需要支持OS.OSIntEnter();    
#endifif(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)  //接收中斷(接收到的數據必須是0x0d 0x0a結尾){Res =USART_ReceiveData(USART1);	//讀取接收到的數據if((USART_RX_STA&0x8000)==0)//接收未完成{if(USART_RX_STA&0x4000)//接收到了0x0d{if(Res!=0x0a)USART_RX_STA=0;//接收錯誤,重新開始else USART_RX_STA|=0x8000;	//接收完成了 }else //還沒收到0X0D{	if(Res==0x0d)USART_RX_STA|=0x4000;else{USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;USART_RX_STA++;if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0;//接收數據錯誤,重新開始接收	  }		 }}   		 } 
#if SYSTEM_SUPPORT_OS 	//如果SYSTEM_SUPPORT_OS為真,則需要支持OS.OSIntExit();  											 
#endif
} 
#endif	

usart.h

#ifndef __USART_H
#define __USART_H
#include "stdio.h"	
#include "sys.h" #define USART_REC_LEN  			200  	//定義最大接收字節數 200
#define EN_USART1_RX 			1		//使能(1)/禁止(0)串口1接收extern u8  USART_RX_BUF[USART_REC_LEN]; //接收緩沖,最大USART_REC_LEN個字節.末字節為換行符 
extern u16 USART_RX_STA;         		//接收狀態標記	
//如果想串口中斷接收,請不要注釋以下宏定義
void uart1_init(u32 bound);
#endif

2、串口2

引腳:TX:PA2;

???????????RX:PA3;

重定向函數:u2_printf();

usart2.c

#include "sys.h"
#include "usart2.h"	  
#include <stdarg.h>
#include <string.h>u8 USART_RX_BUF2[USART_REC_LEN];
//接收狀態
//bit15,	接收完成標志
//bit14,	接收到0x0d
//bit13~0,	接收到的有效字節數目
u16 USART_RX_STA2=0;       //接收狀態標記	  void uart2_init(u32 bound){//GPIO端口設置GPIO_InitTypeDef GPIO_InitStructure;USART_InitTypeDef USART_InitStructure;NVIC_InitTypeDef NVIC_InitStructure;RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);	//使能USART2時鐘RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);	//使能GPIOA時鐘USART_DeInit(USART2);  //復位串口2//USART1_TX   GPIOA.2GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2; //PA.2GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;	//復用推挽輸出GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化GPIOA.2//USART1_RX	  GPIOA.3初始化GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;//PA3GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;//浮空輸入GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化GPIOA.3 //Usart2 NVIC 配置NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=2;  //搶占優先級2NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;		//子優先級3NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;			//IRQ通道使能NVIC_Init(&NVIC_InitStructure);	//根據指定的參數初始化VIC寄存器//USART 初始化設置USART_InitStructure.USART_BaudRate = bound;//串口波特率USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字長為8位數據格式USART_InitStructure.USART_StopBits = USART_StopBits_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(USART2, &USART_InitStructure); //初始化串口2USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);//開啟串口接受中斷USART_Cmd(USART2, ENABLE);                    //使能串口2 }void USART2_IRQHandler(void)                	//串口2中斷服務程序
{u8 Res;if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET)  //接收中斷(接收到的數據必須是0x0d 0x0a結尾){Res =USART_ReceiveData(USART2);	//讀取接收到的數據if((USART_RX_STA2&0x8000)==0)//接收未完成{if(USART_RX_STA2&0x4000)//接收到了0x0d{if(Res!=0x0a)USART_RX_STA2=0;//接收錯誤,重新開始else USART_RX_STA2|=0x8000;	//接收完成了 }else //還沒收到0X0D{	if(Res==0x0d)USART_RX_STA2|=0x4000;else{USART_RX_BUF2[USART_RX_STA2&0X3FFF]=Res ;USART_RX_STA2++;if(USART_RX_STA2>(USART_REC_LEN-1))USART_RX_STA2=0;//接收數據錯誤,重新開始接收	  }		 }}   		 } }char UART2_TX_BUF[200];
void u2_printf(char* fmt, ...)    //無法列出傳遞函數的所有實參的類型和數目時,可以用省略號指定參數表
{u16 i, j;va_list ap;          //va_list 是一個字符指針,可以理解為指向當前參數的一個指針,取參必須通過這個指針進行。va_start(ap, fmt);   //va_start函數來獲取參數列表中的參數,使用完畢后調用va_end()結束vsprintf((char*)UART2_TX_BUF, fmt, ap);	// 把生成的格式化的字符串存放在這里va_end(ap);i = strlen((const char*)UART2_TX_BUF);              //此次發送數據的長度for(j = 0; j < i; j++)                                                    //循環發送數據{while((USART2->SR & 0X40) == 0);                    //循環發送,直到發送完畢USART2->DR = UART2_TX_BUF[j];}
}

usart2.h

#ifndef __USART2_H
#define __USART2_H
#include "stdio.h"	
#include "sys.h" #define USART_REC_LEN  			200  	//定義最大接收字節數 200
#define EN_USART2_RX 			1		//使能(1)/禁止(0)串口1接收extern u8  USART_RX_BUF2[USART_REC_LEN]; //接收緩沖,最大USART_REC_LEN個字節.末字節為換行符 
extern u16 USART_RX_STA2;         		//接收狀態標記	void uart2_init(u32 bound);
void u2_printf(char* fmt, ...);
#endif

3、串口3

引腳:TX:PB10;

???????????RX:PB11;

重定向函數:u3_printf();

usart3.c

#include "sys.h"
#include "usart3.h"
#include "stdarg.h"	 	 
#include "stdio.h"	 	 
#include "string.h"	
// 	 
//如果使用ucos,則包括下面的頭文件即可.
#if SYSTEM_SUPPORT_OS
#include "includes.h"					//ucos 使用	  
#endif#if EN_USART3_RX
u8  USART3_RX_BUF[USART3_REC_LEN]; 	//接收緩沖,最大USART_REC_LEN個字節.末字節為換行符 
u8  USART3_TX_BUF[USART3_SED_LEN]; 	//發送緩沖,最大USART3_SED_LEN個字節.末字節為換行符
u16 USART3_RX_STA = 0;         			//接收狀態標記	void u3_printf(char* fmt,...)  
{  u16 i,j; va_list ap; va_start(ap,fmt);vsprintf((char*)USART3_TX_BUF,fmt,ap);va_end(ap);i=strlen((const char*)USART3_TX_BUF);		//此次發送數據的長度for(j=0;j<i;j++)							//循環發送數據{while(USART_GetFlagStatus(USART3,USART_FLAG_TC)==RESET); //循環發送,直到發送完畢   USART_SendData(USART3,USART3_TX_BUF[j]); } 
}void uart3_init(u32 bound)
{NVIC_InitTypeDef NVIC_InitStructure;GPIO_InitTypeDef GPIO_InitStructure;USART_InitTypeDef USART_InitStructure;RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);	// GPIOB時鐘RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3,ENABLE); //串口3時鐘使能USART_DeInit(USART3);  //復位串口3//USART3_TX   PB10GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; //PB10GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;	//復用推挽輸出GPIO_Init(GPIOB, &GPIO_InitStructure); //初始化PB10//USART3_RX	  PB11GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;//浮空輸入GPIO_Init(GPIOB, &GPIO_InitStructure);  //初始化PB11USART_InitStructure.USART_BaudRate = bound;//波特率一般設置為9600;USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字長為8位數據格式USART_InitStructure.USART_StopBits = USART_StopBits_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(USART3, &USART_InitStructure); //初始化串口	3USART_Cmd(USART3, ENABLE);                    //使能串口 //使能接收中斷USART_ITConfig(USART3, USART_IT_RXNE, ENABLE);//開啟中斷   //設置中斷優先級NVIC_InitStructure.NVIC_IRQChannel = USART3_IRQn;NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0 ;//搶占優先級3NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;		//子優先級3NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;			//IRQ通道使能NVIC_Init(&NVIC_InitStructure);	//根據指定的參數初始化VIC寄存器USART3_RX_STA=0;		//清零
}void USART3_IRQHandler(void) // 串口3中斷服務函數
{u8 res;if(USART_GetITStatus(USART3,USART_IT_RXNE)) // 中斷標志{res= USART_ReceiveData(USART3);  // 串口3 接收if((USART3_RX_STA&0x8000)==0)//接收未完成{if(USART3_RX_STA&0x4000)//接收到了0x0d{if(res!=0x0a)USART3_RX_STA=0;//接收錯誤,重新開始else USART3_RX_STA|=0x8000;	//接收完成了 }else{ 							//還沒收到0X0Dif(res==0x0d)USART3_RX_STA|=0x4000;else{USART3_RX_BUF[USART3_RX_STA&0X3FFF]=res ;USART3_RX_STA++;if(USART3_RX_STA>(USART3_REC_LEN-1))USART3_RX_STA=0;//接收數據錯誤,重新開始接收	  }		 }} }
}#endif

usart3.h

#ifndef __USART3_H
#define __USART3_H
#include "stdio.h"	
#include "sys.h" #define USART3_REC_LEN  			200  	//定義最大接收字節數 200
#define USART3_SED_LEN  			200  	//定義最大發送字節數 200
#define EN_USART3_RX 			1			//使能(1)/禁止(0)串口3接收
extern u8  USART3_RX_BUF[USART3_REC_LEN]; 	//接收緩沖,最大USART3_REC_LEN個字節.末字節為換行符 
extern u8  USART3_TX_BUF[USART3_SED_LEN]; 	//發送緩沖,最大USART3_SED_LEN個字節.末字節為換行符
extern u16 USART3_RX_STA;         			//接收狀態標記	
void uart3_init(u32 bound);
void u3_printf(char* fmt,...);
#endif

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/21797.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/21797.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/21797.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Deno入門:Node.js的現代替代品

Deno 作為 Node.js 的現代替代品&#xff0c;提供了許多改進和創新&#xff0c;尤其是在安全性、模塊系統和開發體驗方面。雖然它仍處于發展階段&#xff0c;但對于尋求簡潔、安全和現代化 JavaScript/TypeScript 開發環境的開發者來說&#xff0c;Deno 是一個值得考慮的選擇。…

【封裝】Unity切換場景不銷毀物體

在切換場景時&#xff0c;如果物體不需要銷毀&#xff0c;可以直接使用下方腳本 代碼 public class DontDestroyLoader : MonoBehaviour{ //所有不銷毀的物體預制體[SerializeField] private GameObject[] dontDestroyPrefabs;//實例化預制體public void Load(){foreach (var …

Linux CFS調度器簡介

文章目錄 前言一、概要二、實現2.1 簡介2.2 算法實現2.3 內核源碼 三、特點四、調度策略五、調度類參考資料 前言 早期的Linux調度器采用了簡化的設計&#xff0c;顯然并不針對具有許多處理器甚至超線程的大規模架構。Linux 1.2調度器使用循環隊列對可運行任務進行管理&#x…

flink實戰--大狀態任務調優指南

Flink 狀態(State)簡介 在 Flink 中,狀態管理是流處理應用的核心概念之一,它允許算子(operators)在處理事件時保持和操作狀態信息。在 Flink 中,狀態可以被視為算子的“記憶”,它使得算子能夠在處理無界流數據時保持對歷史數據的跟蹤。狀態可以是簡單的鍵值對,也可以是…

昆侖萬維官宣開源2000億稀疏大模型Skywork-MoE

6月3日&#xff0c;昆侖萬維宣布開源2千億稀疏大模型Skywork-MoE&#xff0c;性能強勁&#xff0c;同時推理成本更低。 據「TMT星球」了解&#xff0c;Skywork-MoE基于之前昆侖萬維開源的Skywork-13B模型中間checkpoint擴展而來&#xff0c;是首個完整將MoE Upcycling技術應用…

北京Profinet轉Modbus網關配置調試詳解

一、背景&#xff1a;在工業自動化系統中&#xff0c;PLC&#xff08;可編程邏輯控制器&#xff09;與流量計之間的通信是非常重要的&#xff0c;以確保數據準確傳輸并實現控制功能。然而&#xff0c;由于PLC和流量計可能采用不同的通信協議&#xff08;如Profinet和Modbus&…

探索Java的DNA-JVM字節碼深度解析

引言 在Java的世界里&#xff0c;JVM&#xff08;Java虛擬機&#xff09;是我們程序運行的心臟。而字節碼&#xff0c;作為JVM的血液&#xff0c;攜帶著程序的執行指令。今天&#xff0c;我們將深入探索Java字節碼的奧秘&#xff0c;一窺JVM如何將人類可讀的代碼轉化為機器可執…

洛谷 P1438 無聊的數列

題意 給定一個序列 A ( A 1 , A 2 , ? , A n ) A(A_1,A_2,\cdots,A_n) A(A1?,A2?,?,An?)。 現在進行 m m m次操作&#xff0c;分為以下兩種: 1 l r k d&#xff1a;給定一個長度為 r ? l 1 r-l1 r?l1的等差序列&#xff0c;首項為 k k k&#xff0c;公差為 d d d&am…

【小白向】微信小程序解密反編譯教程

# 前言 最近筆者有做到微信小程序的滲透測試&#xff0c;其中有一個環節就是對微信小程序的反編譯進行源碼分析&#xff0c;所謂微信小程序反編譯&#xff0c;就是將訪問的小程序進行反向編譯拿到部分源碼&#xff0c;然后對源碼進行安全審計&#xff0c;分析出其中可能存在的…

圖形學初識--顏色混合

文章目錄 前言正文為什么要有顏色混合&#xff1f;顏色混合常見實現方式&#xff1f;上述顏色混合注意點 結尾&#xff1a;喜歡的小伙伴點點關注贊哦! 前言 本章節補充一下顏色混合的內容&#xff0c;主要包含&#xff1a;為什么要有顏色混合&#xff1f;顏色混合常實現方式&a…

BGP——邊界網關路由協議

BGP -邊界網關路由協議 OSPF RIP EIGRP AS——自治系統 標準編號16位二進制 0-65535 1-64511公有 64512 -私有 擴展編號 32位二進制 動態路由協議: GP ——內部網關路由協議 —— AS之內 或企業網、局域網 RIP OSPF EIGRP EGP-外部網關路由協議 - …

Centos 7 安裝刻錄至硬件服務器

前言 在日常測試中&#xff0c;會遇到很多安裝的場景&#xff0c;今天給大家講一下centos 7 的安裝&#xff0c;希望對大家有所幫助。 一.下載鏡像 地址如下&#xff1a; centos官方鏡像下載地址https://www.centos.org/download/ 按照需求依次點擊下載 二.鏡像刻錄 鏡像刻…

idea springboot woff/woff2/eot/ttf/svg等小圖標不顯示的問題 - 第515篇

歷史文章&#xff08;文章累計500&#xff09; 《國內最全的Spring Boot系列之一》 《國內最全的Spring Boot系列之二》 《國內最全的Spring Boot系列之三》 《國內最全的Spring Boot系列之四》 《國內最全的Spring Boot系列之五》 《國內最全的Spring Boot系列之六》 《…

Shopify 獨立站監控觀測最佳實踐

Shopify 簡介 Shopify 是一個全球領先的電子商務平臺&#xff0c;它為商家提供了一整套在線商店解決方案。自 2006 年成立以來&#xff0c;Shopify 已經幫助數百萬商家在全球范圍內建立和發展他們的在線業務。 監控觀測 Shopify 站點對于確保業務連續性、優化用戶體驗和提高運…

python虛擬環境venv的安裝--ubuntu

venv是Python內置的虛擬環境管理工具 1.安裝python3-venv包&#xff1a; sudo apt install python3.12-venv2.創建虛擬環境&#xff08;在項目目錄下&#xff09; python3 -m venv venv3. 激活虛擬環境&#xff1a; source venv/bin/activate4.在虛擬環境中安裝所需的庫&am…

Linux shell編程學習筆記56:date命令——顯示或設置系統時間與日期

0 前言 2024年的網絡安全檢查又開始了&#xff0c;對于使用基于Linux的國產電腦&#xff0c;我們可以編寫一個腳本來收集系統的有關信息。在收集的信息中&#xff0c;應該有一條是搜索信息的時間。 1. date命令 的功能、格式和選項說明 我們可以使用命令 date --help 來查看 d…

python 虛擬環境安裝及python包庫安裝

python 虛擬環境安裝及python包庫安裝 安裝虛擬環境的方式注意事項 安裝虛擬環境的方式 切記盡量不要混用 pip 安裝 對于pip安裝&#xff0c;使用命令如下 下載virtualenv 工具 pip install virtualenv 創建虛擬環境并激活環境virtualenv venv source ./venv/bin/activate co…

Kafka之Broker原理

1. 日志數據的存儲 1.1 Partition 1. 為了實現橫向擴展&#xff0c;把不同的數據存放在不同的 Broker 上&#xff0c;同時降低單臺服務器的訪問壓力&#xff0c;我們把一個Topic 中的數據分隔成多個 Partition 2. 每個 Partition 中的消息是有序的&#xff0c;順序寫入&#x…

LeetCode刷題:反轉鏈表

leetCode真題 206. 反轉鏈表 屬于基礎簡單題目 常見的做法有遞歸和while循環 遞歸 // 1. 遞歸參數和返回值public static ListNode reverseList(ListNode head) {// 1. 遞歸終止條件if (head null || head.next null) {return head;}// 遞歸邏輯ListNode last reverseL…

達夢數據庫相關SQL及適配Mysql配置總結

&#x1f353; 簡介&#xff1a;java系列技術分享(&#x1f449;持續更新中…&#x1f525;) &#x1f353; 初衷:一起學習、一起進步、堅持不懈 &#x1f353; 如果文章內容有誤與您的想法不一致,歡迎大家在評論區指正&#x1f64f; &#x1f353; 希望這篇文章對你有所幫助,歡…