apue读书笔记【二】:处理可变参数(2) vsnprintf

 vsnprintf  用于向字符串中打印数据、数据格式用户自定义。

我阅读apue书中的源码例子中发现些函数,位置于apue.h  error.c中。作者用可变参数的处理与vsnprintf结合,封装了错误打印的方法。

头文件:
  #include <stdarg.h>
函数声明:
  int vsnprintf(char *buffer, size_t max_count, const char *format, va_list vArgList);
参数说明:
  1. char *buffer [out],把生成的格式化的字符串存放在这里.
  2. size_t max_count [in], buffer可接受的最大字节数,防止产生数组越界.
  3. const char *format [in], 格式化字符串
  4. va_list vArgList [in], va_list变量. va:variable-argument:可变参数
  用法类似于vsprintf,只不过加了max_count的限制


demo:

#include <stdarg.h> /*for va_list*/
#include <stdio.h> /*for vsnprintf*/
/**
    头文件:
  #include <stdarg.h>
  函数声明:
  int vsnprintf(char *buffer, size_t max_count, const char *format, va_list vArgList);
  参数说明:
  1. char *buffer [out],把生成的格式化的字符串存放在这里.
  2. size_t max_count [in], buffer可接受的最大字节数,防止产生数组越界.
  3. const char *format [in], 格式化字符串
  4. va_list vArgList [in], va_list变量. va:variable-argument:可变参数
  用法类似于vsprintf,只不过加了max_count的限制

   返回值说明:
  如果成功调用此函数,返回写到buffer中的字符的个数(不包括结尾的'\0')。snprintf和vsnprintf函数不能够写多于size大小(包括结尾的'0')的字节数。
    如果输出因为以上原因被截断,返回成功写入buffer的字符数(不包括结尾的'\0'),如果有足够的内存空间的话。
	所以,如果返回值等于size或者大于size,表示输出到buffer的字符被截断,如果输出过程中遇到错误,则返回一个负数。
**/

int mon_log(char* format,...){

	 char str_tmp[10];
	 
	 va_list vArgList;//定义一个va_list型的变量,这个变量是指向参数的指针

     va_start(vArgList,format);//用va_start宏初始化变量,这个宏的第二个参数是第一个可变参数的前一个参数,是一个固定的参数.

	 int nSize=vsnprintf(str_tmp,1,format,vArgList);//nSize的大小不包括‘\0’,第二个参数填1是不能写进去内容的(因为'\0'占了一个字节)

	 va_end(vArgList);//用va_end宏结束可变参数的获取

	 printf("nSize: %d, buff: %s\n", nSize, str_tmp);

	 return 0;
}

int main(){
  
   mon_log("%d", 1);
}
输出:

      

由输出可以看出 vsnprintf的返回值就是本应写进buffer缓存区的字符个数,第二个参数的意思就是实际允许写进buffer缓存区的最大字符个数
为了说明第二个参数,调整vsnprintf的第二个参数,demo如下

#include <stdarg.h> /*for va_list*/
#include <stdio.h> /*for vsnprintf*/
/**
    头文件:
  #include <stdarg.h>
  函数声明:
  int vsnprintf(char *buffer, size_t max_count, const char *format, va_list vArgList);
  参数说明:
  1. char *buffer [out],把生成的格式化的字符串存放在这里.
  2. size_t max_count [in], buffer可接受的最大字节数,防止产生数组越界.
  3. const char *format [in], 格式化字符串
  4. va_list vArgList [in], va_list变量. va:variable-argument:可变参数
  用法类似于vsprintf,只不过加了max_count的限制

   返回值说明:
  如果成功调用此函数,返回写到buffer中的字符的个数(不包括结尾的'\0')。snprintf和vsnprintf函数不能够写多于size大小(包括结尾的'0')的字节数。
    如果输出因为以上原因被截断,返回成功写入buffer的字符数(不包括结尾的'\0'),如果有足够的内存空间的话。
	所以,如果返回值等于size或者大于size,表示输出到buffer的字符被截断,如果输出过程中遇到错误,则返回一个负数。
**/

int mon_log(char* format,...){

	 char str_tmp[10];
	 
	 va_list vArgList;//定义一个va_list型的变量,这个变量是指向参数的指针

     va_start(vArgList,format);//用va_start宏初始化变量,这个宏的第二个参数是第一个可变参数的前一个参数,是一个固定的参数.

	 int nSize=vsnprintf(str_tmp,10,format,vArgList);//nSize的大小不包括‘\0’,第二个参数填1是不能写进去内容的(因为'\0'占了一个字节)

	 va_end(vArgList);//用va_end宏结束可变参数的获取

	 printf("nSize: %d, buff: %s\n", nSize, str_tmp);

	 return 0;
}

int main(){
  
   mon_log("%d,%d,%d,%d", 1,2,3,4);
}

输出:

       

自己把程序拿下来改改,再跑跑就清楚很多了。


demo不怕多,再来一个:

#include <stdio.h>
#include <stdarg.h> /*for va_list*/
#include <memory.h> /*for memset*/

void FormatOutput(char*  formatstring, ...)
{
   int nSize = 0;
   char buff[10];
   memset(buff, 0, sizeof(buff));
   va_list args;
   va_start(args, formatstring);
   nSize = vsnprintf( buff, sizeof(buff) - 1, formatstring, args); // C4996
// Note: vsnprintf is deprecated; consider vsnprintf_s instead
   printf("nSize: %d, buff: %s\n", nSize, buff);
}

int main() {
   FormatOutput("%s %s", "Hi", "there");
   FormatOutput("%s %s", "Hi", "there!");
   FormatOutput("%s %s", "Hi", "there!!");
   return 0;
}





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值