一、printf重定向简介

  我们知道C语言中printf函数默认输出设备是显示器,如果要实现在 串口或者LCD上显示,必须重定义标准库函数里调用的与输出设备相关的函数。比如使用printf输出到串口,需要将fputc里面的输出指向串口, 这一过程就叫重定向。 那么如何让STM32使用printf函数呢?

int fputc(int ch,FILE *p) //函数默认的,在使用printf函数时自动调用

{

  USART_SendData(USART1,(u8)ch);

  while(USART_GetFlagStatus(USART1,USART_FLAG_TXE)==RESET);

  return ch;

}

二、printf函数格式

printf("<格式化字符串>", <参量表>);

//.h文件
1 #ifndef __usart_H
2 #define __usart_H
3
4 #include "system.h"
5 #include "stdio.h"
6
7 void USART1_Init(u32 bound);
8
9
10 #endif

//.c文件
 1 #include "usart.h"
2
3 int fputc(int ch,FILE *p) //函数默认的,在使用printf函数时自动调用
4 {
5 USART_SendData(USART1,(u8)ch);
6 while(USART_GetFlagStatus(USART1,USART_FLAG_TXE)==RESET);
7 return ch;
8 }
9
10 /*******************************************************************************
11 * 函 数 名 : USART1_Init
12 * 函数功能 : USART1初始化函数
13 * 输 入 : bound:波特率
14 * 输 出 : 无
15 *******************************************************************************/
16 void USART1_Init(u32 bound)
17 {
18 //GPIO端口设置
19 GPIO_InitTypeDef GPIO_InitStructure;
20 USART_InitTypeDef USART_InitStructure;
21 NVIC_InitTypeDef NVIC_InitStructure;
22
23 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
24 RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
25 RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE); //打开时钟
26
27
28 /* 配置GPIO的模式和IO口 */
29 GPIO_InitStructure.GPIO_Pin=GPIO_Pin_9;//TX //串口输出PA9
30 GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
31 GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AF_PP; //复用推挽输出
32 GPIO_Init(GPIOA,&GPIO_InitStructure); /* 初始化串口输入IO */
33 GPIO_InitStructure.GPIO_Pin=GPIO_Pin_10;//RX //串口输入PA10
34 GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING; //模拟输入
35 GPIO_Init(GPIOA,&GPIO_InitStructure); /* 初始化GPIO */
36
37
38 //USART1 初始化设置
39 USART_InitStructure.USART_BaudRate = bound;//波特率设置
40 USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字长为8位数据格式
41 USART_InitStructure.USART_StopBits = USART_StopBits_1;//一个停止位
42 USART_InitStructure.USART_Parity = USART_Parity_No;//无奇偶校验位
43 USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无硬件数据流控制
44 USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; //收发模式
45 USART_Init(USART1, &USART_InitStructure); //初始化串口1
46
47 USART_Cmd(USART1, ENABLE); //使能串口1
48
49 USART_ClearFlag(USART1, USART_FLAG_TC);
50
51 USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//开启相关中断
52
53 //Usart1 NVIC 配置
54 NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;//串口1中断通道
55 NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3;//抢占优先级3
56 NVIC_InitStructure.NVIC_IRQChannelSubPriority =3; //子优先级3
57 NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道使能
58 NVIC_Init(&NVIC_InitStructure); //根据指定的参数初始化VIC寄存器、
59 }
60
61 /*******************************************************************************
62 * 函 数 名 : USART1_IRQHandler
63 * 函数功能 : USART1中断函数
64 * 输 入 : 无
65 * 输 出 : 无
66 *******************************************************************************/
67 void USART1_IRQHandler(void) //串口1中断服务程序
68 {
69 u8 r;
70 if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //接收中断
71 {
72 r =USART_ReceiveData(USART1);//(USART1->DR); //读取接收到的数据
73 USART_SendData(USART1,r);
74 while(USART_GetFlagStatus(USART1,USART_FLAG_TC) != SET);
75 }
76 USART_ClearFlag(USART1,USART_FLAG_TC);
77 }
 // main文件
1 #include "system.h"
2 #include "SysTick.h"
3 #include "led.h"
4 #include "usart.h"
5
6
7 /*******************************************************************************
8 * 函 数 名 : main
9 * 函数功能 : 主函数
10 * 输 入 : 无
11 * 输 出 : 无
12 *******************************************************************************/
13 int main()
14 {
15 u8 i=0;
16 u16 data=1234;
17 float fdata=12.34;
18 char str[]="Hello World!";
19 SysTick_Init(72);
20 NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2); //中断优先级分组 分2组
21 LED_Init();
22 USART1_Init(9600);
23
24 while(1)
25 {
26 i++;
27 if(i%20==0)
28 {
29 led1=!led1;
30
31 printf("输出整型数data=%d\r\n",data);
32 printf("输出浮点型数fdata=%0.2f\r\n",fdata);
33 printf("输出十六进制数data=%X\r\n",data);
34 printf("输出八进制数data=%o\r\n",data);
35 printf("输出字符串str=%s\r\n",str);
36
37 }
38 delay_ms(10);
39 }
40 }

(stm32f103学习总结)—printf重定向的更多相关文章

  1. stm32中如何进行printf重定向用于串口调试输出

    1 在main中包含stdio.h 文件 2 Target选项框里选Use MicroLib 选项 3 在main中添加UART1_Configuration()初始化的代码 Uart1初始化,voi ...

  2. Java SE学习之printf 日期转换符

    本文是学习网络上的文章时的总结,感谢大家无私的分享. System.out.printf()方法能够对日期做处理输出. 相应列表 转换符 类型 举例 c 完整的日期和时间 Mon Feb 09 18: ...

  3. 笔记:stm32 printf重定向到UART疑点解析

    在调试过程中往往需要通过打印来看系统运行状态:在STM32平台上,打印重定向有多种实现方案:其一是编译时使用keil自带的MacroLIB,据说这个库对一些C语言基础设施做了新的实现,代码结构更加紧凑 ...

  4. 批处理学习笔记6 - 重定向符>和>>

    重定向符大概有6,7种,和%符号差不多各有各的用途.这里学习>和>> >  是左边的值把右边的值覆盖 >> 是左边的值添加在右边的值上面 rem 是批处理的注释,类 ...

  5. STM32中printf重定向到串口

    学习STM32过程中,经常打交道的莫过于串口,你可以将任何信息,当然重要的是调试信息打印到串口中输出,总是用一个字节发送函数或者字符串发送函数 总是有些不放便,之前编程中熟悉的莫过于printf了,下 ...

  6. stm32 printf重定向

    printf函数调用fputc int fputc(int ch, FILE *p) { USART_SendData(USART1, ch); //重定向到串口 while(USART_GetFla ...

  7. STM32F103学习进程

    软硬件下载程序和程序运行的相关问题和解决方案,以我自身买的STM32F103C8T6为例 (1) 硬件需要 1. 购买一个STM32F103XXX的板子.这是一个操作实践性非常强的一个学习过程,如果没 ...

  8. (stm32f103学习总结)—GPIO结构

    一.GPIO基本结构 二.GPIO工作模式 输入模式 输入浮空 输入上拉 输入下拉 模拟输入 输出模式 开漏输出 开漏复用功能 推挽式输出 推挽式复用功能 库函数中所对应的代码 1 typedef e ...

  9. (stm32f103学习总结)—输入捕获模式

    一.输入捕获介绍 在定时器中断实验章节中我们介绍了通用定时器具有多种功能,输入捕获就是其中一种.STM32F1 除了基本定时器 TIM6 和 TIM7,其他定时器都具有输入捕获功能.输入捕获可以对输入 ...

随机推荐

  1. 【用户状态】详细解读Oracle用户ACCOUNT_STATUS的九种状态

    转至:http://blog.itpub.net/519536/viewspace-672276/ DBA_USERS视图中ACCOUNT_STATUS记录的用户的当前状态,一般情况下在使用的正常用户 ...

  2. c/c++ 内存泄漏分析

    Valgrind: https://zhuanlan.zhihu.com/p/111556601 valgrind输出结果分析 valgrind输出结果会报告5种内存泄露,"definite ...

  3. Write Combining Buffer

    现代CPU使用了很多技术来降低对内存存取数据的延时,因为CPU执行的速度实在是太快了,在从内存存取数据的约120ns中,可以执行数百条指令. 其中多级的缓存架构就是为了减少这种延时,来提高CPU的利用 ...

  4. HDFS连接JAVA,HDFS常用API

    先在pom.xml中导入依赖包 <dependencies> <!-- https://mvnrepository.com/artifact/org.apache.hadoop/ha ...

  5. eval()计算某个字符串,js和jquery都可以使用

    实例 执行JavaScript代码或表达式: <script>eval("x=10;y=20;document.write(x*y)");document.write( ...

  6. Linux安装JDK8环境

    1.下载JDK包 点击同意下载后,会让你注册oracel账号,登录了才能下载 2.上传到linux服务器,然后解压 解压命令(注意jdk的版本名称不一定相同): tar -zxvf jdk-8u181 ...

  7. Mac下如何自动备份目录到七牛云?

    原文链接 七牛云是个很好用的图床,但是 Mac 下并没有什么很好用的客户端,每次上传都需要在网页上手动一个个传文件,十分麻烦,于是仔细看了下七牛云的部分文档,打算使用QRSBox来自动上传图片. QR ...

  8. 金蝶 K3 WISE 服务器必须登陆到桌面以后用户才能正常使用解决!

    我们单位K3的系统,由当地的服务商安装完以后就出现各种蛋疼的问题.做技术支持的小伙他总是会给一个小工具来解决,问他是什么原因要么说我的网络有问题,要么说我们的服务器有问题. K3所有客户端无法登陆一键 ...

  9. CVE-2018-12613phpMyAdmin 后台文件包含漏洞分析

    一.    漏洞背景 phpMyAdmin 是一个以PHP为基础,以Web-Base方式架构在网站主机上的MySQL的数据库管理工具,让管理者可用Web接口管理MySQL数据库.借由此Web接口可以成 ...

  10. Spring Boot 自定义Starter 可能引发的问题(Error)

    如果你的项目出现: Consider defining a bean of type 'com.wy.helloworld_spring_boot_starter.PersonService' in ...