嵌入式开发打印,我放弃了printf…

嵌入式ARM 2023-01-11 12:00

对于printf,相信不用我过多介绍,大家在初学C语言时用得最多的信息输出接口函数应该就是printf了。对于玩MCU、Linux等嵌入式的朋友,基本上都会用其进行串口日志打印。

printf是将字符串到标准输出stdout,比如标准输出是屏幕、串口终端等等,由于用户需求不一样都会进行输出的重定向,从而打印信息到想要的输出设备上。

而今天的主角sprintf是字符串格式化命令,与printf相比我觉得其更多的是一个转换函数,类似于大写转化为小写。sprintf可以按照用户定义的格式转为对应的字符串并填充到缓冲buff中。

所以,printf其实相当于sprintf+把字符串输出到标准输出”,有些平台printf函数其实就是这两种的封装。因此printf的重定向就可以认为仅仅只是改变了标准的输出接口。

不知曾几何时,接触到了sprintf以后,在实际的项目中就很少再去使用printf,因为sprintf的强大完全可以替代printf,并且在有些应用中显得非常灵活。

1

体验sprintf


首先,我们了解一下sprintf。

Fuction :int sprintf(char *string, char *format [,argument,...]);

Param1 : 最终格式化字符串所存储的buff。

Param2 : 可变参数,类似于printf中的”%d”格式。

return最终打印到字符缓冲区中的字符数目,结束字符‘\0’不计入内。

参考示例:
#include 

char strBuff[40] ={'\n'};

/********************************************
 * Fuction : UartString
 * Descri  : 进行sprintfDemo演示 
 * Author  : bug菌 
 *******************************************/
 
void UartString(char * strBuff) 
{   //模拟串口输出 
 printf("%s\r\n",strBuff);
}

/********************************************
 * Fuction : main
 * Descri  : 进行sprintfDemo演示 
 * Author  : bug菌 
 *******************************************/
 
int main(void)
{
 int strIndex = 0;
  
 //打印整形 
 sprintf(strBuff,"bugNum = %d",1000);
 UartString(strBuff); 
 
 //打印浮点 
 sprintf(strBuff,"PI = %.4f",3.1415926);
 UartString(strBuff); 
 
 //打印地址
 sprintf(strBuff,"address = %p",&strIndex);
 UartString(strBuff); 
 
 //字符串拼接
 strIndex = sprintf(strBuff,"PI = %.4f",3.1415926);
  strIndex = sprintf(strBuff+strIndex,"926");
 UartString(strBuff); 
 
  //简单输出
  strIndex = sprintf(strBuff,"欢迎大家关注公众号:最后一个bug");
  UartString(strBuff); 
  return 0;
}

结果输出:

说明一下:
从上面的演示了解到printf与sprintf仅仅只是其前面增加了一个buff缓冲,其可变参数格式部分用法与printf几乎相同。
而且通过利用sprintf返回值还可以方便、灵活的进行多个字符串的拼接, 相比strcat进行两个字符串拼接确实要方便多了。

2

sprintf注意事项


(1)buff溢出
sprintf最大的问题是容易缓存区溢出,一旦可变部分所拼接的字符串长度超过buff的大小,便会造成数据溢出,从而危及程序运行。特别是在进行浮点操作的时候尤为要注意,比如把上面的Demo浮点数打印不进行格式处理。
 //打印浮点 
 //sprintf(strBuff,"PI = %.4f",3.14);
 sprintf(strBuff,"PI = %f",3.14);
 UartString(strBuff); 


相比预期的输3.14 后面增加了0000,如果strbuff定义的过小就会导致数据溢出。

(2)snprintf

由于使用sprintf开发者容易导致缓冲区溢出,然而这样的bug有时候隐藏得比较深,导致难以排查,所以就有了一个安全性稍微高一点的snprintf函数,该函数在sprintf函数的基础上增加了一个缓冲区长度的参数,通过该参数函数内部用来避免sprintf()存在的溢出风险。

Fuction :int snprintf(char *str, size_t size, const char *format, ...);
Param1 最终格式化字符串所存储的buff。
Param2 buff缓存区的长度。
Param3 : 可变参数,类似于printf中的”%d”格式。
return : 若成功则返回预写入的字符串长度,若出错则返回负数。
参考示例:
#include 

#define BUFF_SIZE 11
char strBuff[BUFF_SIZE] ={'\n'};

/********************************************
 * Fuction : UartString
 * Descri  : 进行sprintfDemo演示 
 * Author  : bug菌 
 *******************************************/
 
void UartString(char * strBuff) 
{   //模拟串口输出 
 printf("%s\r\n",strBuff);
}

/********************************************
 * Fuction : main
 * Descri  : 进行snprintfDemo演示 
 * Author  : bug菌 
 *******************************************/
 
int main(void)
{
 int strIndex = 0;
  
    //打印浮点 
 printf("return :%d\n",snprintf(strBuff,BUFF_SIZE,"PI = %f\r\n",3.14)) ;
 UartString(strBuff); 
 
 return 0;
}

输出结果:

说明一下:
需要注意一点,snprintf返回的是预写字符串长度,而非最终写入到strbuff中的字符个数。当然,当缓存区足够的时候预写长度=最终写入到strbuff中的字符串长度。

3

简化版snprintf


一个功能全面的printf、sprintf、snprintf等等都会有较大的代码量,同样标准C库的也是一样的,对于一些资源比较紧张的MCU等可能一个标准函数就占用了一大半的Flash等ROM区,一个库函数实现比主体代码还耗资源,这样在嵌入式中是不应该的。
然而,对于这些printf函数,其实我们并不需要其全部的功能,可能只需要个打印整形、浮点等数据即可满足需求。至于其他格式的代码实现,完全可以去除,从而可以大大缩减其占用的ROM资源,所以就有了精简版的snprintf。对于snprintf,可以在标准库源码上进行相关功能的删减即可,由于篇幅有限,这里就不过多介绍了,网络上资源也是一大把,感兴趣的朋友可以自行搜索一下。

好了,今天的知识就跟大家分享到这里,sprintf还有很多巧妙的格式等你去挖掘,相信这是一段美妙的学习之旅!

END

来源:最后一个bug

版权归原作者所有,如有侵权,请联系删除。

推荐阅读
曾经对程序员最好的公司,倒下了…
一款活跃了17年的开发工具,好用到起飞~
单片机只会调库和复制别人的代码是什么水平?

→点关注,不迷路←

嵌入式ARM 关注这个时代最火的嵌入式ARM,你想知道的都在这里。
评论 (0)
  • ‌磁光克尔效应(Magneto-Optic Kerr Effect, MOKE)‌ 是指当线偏振光入射到磁性材料表面并反射后,其偏振状态(偏振面旋转角度和椭偏率)因材料的磁化强度或方向发生改变的现象。具体表现为:1、‌偏振面旋转‌:反射光的偏振方向相对于入射光发生偏转(克尔旋转角 θK)。2、‌椭偏率变化‌:反射光由线偏振变为椭圆偏振(克尔椭偏率 εK)。这一效应直接关联材料的磁化状态,是表征磁性材料(如铁磁体、反铁磁体)磁学性质的重要非接触式光学探测手段,广泛用于
    锦正茂科技 2025-05-12 11:02 297浏览
  •   电磁数据展示系统平台解析   北京华盛恒辉电磁数据展示系统平台是实现电磁数据高效展示、分析与管理的综合性软件体系,以下从核心功能、技术特性、应用场景及发展趋势展开解读:   应用案例   目前,已有多个电磁数据展示系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润电磁数据展示系统。这些成功案例为电磁数据展示系统的推广和应用提供了有力支持。   一、核心功能模块   数据采集与预处理   智能分析处理   集成频谱分析、时频变换等信号处理算法,自动提取时域频域特征;
    华盛恒辉l58ll334744 2025-05-13 10:20 361浏览
  • 感谢面包板论坛组织的本次测评活动,本次测评的对象是STM32WL Nucleo-64板 (NUCLEO-WL55JC) ,该测试板专为LoRa™应用原型构建,基于STM32WL系列sub-GHz无线微控制器。其性能、功耗及特性组合经过精心挑选,支持通过Arduino® Uno V3连接,并利用ST morpho接头扩展STM32WL Nucleo功能,便于访问多种专用屏蔽。STM32WL Nucleo-64板集成STLINK-V3E调试器与编程器,无需额外探测器。该板配备全面的STM
    无言的朝圣 2025-05-13 09:47 151浏览
  •   定制软件开发公司推荐清单   在企业数字化转型加速的2025年,定制软件开发需求愈发多元复杂。不同行业、技术偏好与服务模式的企业,对开发公司的要求大相径庭。以下从技术赛道、服务模式及行业场景出发,为您提供适配的定制软件开发公司推荐及选择建议。   华盛恒辉科技有限公司:是一家专注于高端软件定制开发服务和高端建设的服务机构,致力于为企业提供全面、系统的开发制作方案。在部队政企开发、建设到运营推广领域拥有丰富经验,在教育,工业,医疗,APP,管理,商城,人工智能,部队软件、工业软件、数字化转
    华盛恒辉l58ll334744 2025-05-12 15:55 332浏览
  • 在当下竞争激烈的 AI 赛道,企业高层的变动往往牵一发而动全身,零一万物近来就深陷这样的动荡漩涡。近日,零一万物联合创始人、技术副总裁戴宗宏离职创业的消息不胫而走。这位在大模型基础设施领域造诣颇深的专家,此前在华为云、阿里达摩院积累了深厚经验,在零一万物时更是带领团队短期内完成了千卡 GPU 集群等关键设施搭建,其离去无疑是重大损失。而这并非个例,自 2024 年下半年以来,李先刚、黄文灏、潘欣、曹大鹏等一众联创和早期核心成员纷纷出走。
    用户1742991715177 2025-05-13 21:24 109浏览
  •   舰艇电磁兼容分析与整改系统平台解析   北京华盛恒辉舰艇电磁兼容分析与整改系统平台是保障海军装备作战效能的关键技术,旨在确保舰艇电子设备在复杂电磁环境中协同运行。本文从架构、技术、流程、价值及趋势五个维度展开解析。   应用案例   目前,已有多个舰艇电磁兼容分析与整改系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润舰艇电磁兼容分析与整改系统。这些成功案例为舰艇电磁兼容分析与整改系统的推广和应用提供了有力支持。   一、系统架构:模块化智能体系   电磁环境建模:基
    华盛恒辉l58ll334744 2025-05-14 11:22 45浏览
  • 在全球供应链紧张和国产替代需求推动下,国产存储芯片产业快速发展,形成设计到封测一体化的完整生态。北京君正、兆易创新、紫光国芯、东芯股份、普冉股份和佰维存储等六大上市公司在NOR/NAND Flash、DRAM、嵌入式存储等领域布局各具特色,推动国产替代提速。贞光科技代理的品牌紫光国芯,专注DRAM技术,覆盖嵌入式存储与模组解决方案,为多领域客户提供高可靠性产品。随着AI、5G等新兴应用兴起,国产存储厂商有望迎来新一轮增长。存储芯片分类与应用易失性与非易失性存储芯片易失性存储芯片(Volatile
    贞光科技 2025-05-12 16:05 200浏览
  • 文/Leon编辑/cc孙聪颖‍2025年1月至今,AI领域最出圈的除了DeepSeek,就是号称首个“通用AI Agent”(智能体)的Manus了,其邀请码一度被炒到8万元。很快,通用Agent就成为互联网大厂、AI独角兽们的新方向,迅速地“卷”了起来。国外市场,Open AI、Claude、微软等迅速推出Agent产品或构建平台,国内企业也在4月迅速跟进。4月,字节跳动、阿里巴巴、百度纷纷入局通用Agent市场,主打复杂的多任务、工作流功能,并对个人用户免费。腾讯则迅速更新腾讯元器的API接
    华尔街科技眼 2025-05-12 22:29 148浏览
  • 在 AI 浪潮席卷下,厨电行业正经历着深刻变革。AWE 2025期间,万得厨对外首次发布了wan AiOS 1.0组织体超智能系统——通过AI技术能够帮助全球家庭实现从健康检测、膳食推荐,到食材即时配送,再到一步烹饪、营养总结的个性化健康膳食管理。这一创新之举并非偶然的个案,而是整个厨电行业大步迈向智能化、数字化转型浪潮的一个关键注脚,折射出全行业对 AI 赋能的热切渴求。前有标兵后有追兵,万得厨面临着高昂的研发成本与技术迭代压力,稍有懈怠便可能被后来者赶
    用户1742991715177 2025-05-11 22:44 180浏览
  •   电磁数据管理系统深度解析   北京华盛恒辉电磁数据管理系统作为专业的数据处理平台,旨在提升电磁数据的处理效率、安全性与可靠性。以下从功能架构、核心特性、应用场景及技术实现展开分析:   应用案例   目前,已有多个电磁数据管理系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润电磁数据管理系统。这些成功案例为电磁数据管理系统的推广和应用提供了有力支持。   一、核心功能模块   数据采集与接入:实时接收天线、频谱仪等设备数据,兼容多协议接口,确保数据采集的全面性与实时性
    华盛恒辉l58ll334744 2025-05-13 10:59 271浏览
  •   基于 2025 年行业权威性与时效性,以下梳理国内知名软件定制开发企业,涵盖综合型、垂直领域及特色技术服务商:   华盛恒辉科技有限公司:是一家专注于高端软件定制开发服务和高端建设的服务机构,致力于为企业提供全面、系统的开发制作方案。在部队政企开发、建设到运营推广领域拥有丰富经验,在教育,工业,医疗,APP,管理,商城,人工智能,部队软件、工业软件、数字化转型、新能源软件、光伏软件、汽车软件,ERP,系统二次开发,CRM等领域有很多成功案例。   五木恒润科技有限公司:是一家专业的部队信
    华盛恒辉l58ll334744 2025-05-12 16:13 250浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦