一个误用snprintf的bug分析

本文分析了一个在64位和32位系统下使用snprintf函数出现不同结果的bug,问题出在格式化输出时指定的参数大小不匹配。在32位系统中,由于堆栈操作,错误的格式指定导致取值异常;而在64位系统中,由于使用寄存器传递参数,未引发明显错误。这提醒我们在使用可变参数函数时要注意类型安全。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

snprintf函数的功能是格式化输出到字符串中,函数原型为:

int snprintf(char *str, size_t size, const char *fomat, ...)

正常来说,只要会用printf函数写输出语句,应该都能会用该函数。但是,稍有不留神,很可能踩到其中的坑。现将前段时间遇到的一个问题进行简单地分析。

问题

以下是抽取出来的问题代码段:

#include <stdio.h>
#include <iostream>

class A
{
	public:
		int64_t b;
		char* pstr;
		int a;

};

int main()
{
	char source[128] = "hello world";
	char tstr[128] = "\0";
	A a;
	a.a=0x0001;
	a.b=0x00030004;
	a.pstr = source;

	snprintf(tstr, sizeof(tstr), "b=%ld,str=%s,a=%d\n", a.b, a.pstr, a.a);
	printf("%s",tstr);
	//printf("%s\nsource address:%ld\n",tstr, source); //查找问题时增加

	return 0;
}
如上所示,功能比较简单,就是使用snprintf函数将类A中的变量值格式化输出到tstr字符串中。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值