vsnprintf类型异常时没有编译告警问题

文章展示了在C语言中,由于格式化字符串不匹配导致在某些CPU平台上输出异常的问题。原始代码在传递`unsignedlonglong`类型的`input`到`my_log`函数时,使用了不正确的格式`%d`。更新后的代码通过添加`__attribute__((format(printf,1,2)))`来指定格式字符串和参数的关系,从而在编译阶段产生告警,帮助开发者发现并修复问题。
摘要由CSDN通过智能技术生成

比如有测试代码:

int my_log(char* pFormat, ...)
{
	char str[128] = {0};
	va_list stArgList;                           
	
	va_start (stArgList, pFormat);                
	alreadywrite = vsnprintf(str, 127, pFormat, stArgList);
	va_end(stArgList);
	
	printf("%s", str);

	return 0;                            
}

int main()
{
	unsigned long long input = 1234567890LL;
	my_log("input is %d", input);
	return 0;
}

在某些CPU平台中input值会输出异常,但是编译过程没有告警,如何处理呢?处理后的代码如下图所示,其中1,2表示pFormat是第几个参数:

int __attribute__((format(printf,1,2))) my_log(char* pFormat, ...)
{
	char str[128] = {0};
	va_list stArgList;                           
	
	va_start (stArgList, pFormat);                
	alreadywrite = vsnprintf(str, 127, pFormat, stArgList);
	va_end(stArgList);
	
	printf("%s", str);

	return 0;                            
}

int main()
{
	unsigned long long input = 1234567890LL;
	my_log("input is %d", input);
	return 0;
}

上述代码编译就有告警了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值