sprintf与vsnprintf的区别是,虽然两者都是用可变长度的参数作为格式化的参数,但sprintf要求的是已知个数的参数,但vsnprintf可以使用未知数量的参数长度,因此,明显vsnprintf的capacity较强一些。
sprintf的使用
char logTag[MAX_LOG_MESSAGE_LENGTH];
memset(logTag,0,MAX_LOG_MESSAGE_LENGTH);
sprintf(logTag,"%s[%d].%s",__FILE__,__LINE__,__FUNCTION__);
vsnprintf的使用
#include <stdarg.h>
void LogMessage(const char * format,...)
{
va_list ap;//实例化可变长参数列表
va_start(ap,format); //初始化可变参数列表,设置format为可变长列表的起始点(第一个元素)
vsnprintf(buffer,MAX_LOG_MESSAGE_LENGTH,format,ap);
va_end(ap);//注意必须关闭
}