Windows Linux可兼容版变长参数的实例程序

自己写的一个可变长参数的例子程序。

采用了Linux Windows可兼容版本函数。

main.c

  1. /*
  2.  * This project is implemented for testing variable-argument
  3.  */
  4. #include <stdio.h>
  5. #include <stdlib.h>

  6. #include "log.h"

  7. FILE *fp_log = NULL;

  8. void main(char arg, char *argv[])
  9. {
  10.   if ((fp_log = fopen("test.log", "w+")) == NULL)
  11.   {
  12.     printf("The file 'test.log' was not opened\n");
  13.   }

  14.   tc_log(fp_log, "%s", __FUNCTION__);
  15.   tc_log(fp_log, "%s, %d", __FUNCTION__, 1);
  16.   tc_log(fp_log, "%s, %d, %s, %d", __FUNCTION__, 2, __FUNCTION__, 2);

  17.   if( fclose(fp_log))
  18.     printf( "The file 'test.log' was not closed\n");
  19. }
log.h
  1. /*
  2.  * File: log.h
  3.  */

  4. #ifndef __LOG_H__
  5. #define __LOG_H__
  6. #include <stdarg.h>

  7. typedef char * va_list;
  8. extern FILE *fp_log;

  9. void tc_log(const FILE *fp_log, const char *fmt, ...);
  10. void tc_log_default(const FILE *fp_log, const char * fmt, va_list vl);
  11. #endif
log.c
  1. /*
  2.  * File: log.c
  3.  */
  4. #include "stdio.h"
  5. #include "log.h"


  6. void tc_log(const FILE *fp_log, const char *fmt, ...)
  7. {
  8.   va_list vl;

  9.   /* Macro to set 'vl' to beginning of list of optional arguments */ 
  10.   va_start(vl, fmt);
  11.   
  12.   tc_log_default(fp_log, fmt, vl);
  13.   
  14.   /* Macro to reset arg_ptr */
  15.   va_end(vl);

  16.   return;
  17. }

  18. void tc_log_default(const FILE *fp_log, const char * fmt, va_list vl)
  19. {
  20.   char line[1024];
  21.   line[0] = 0;
  22.   printf("strlen = %d, sizeof = %d\n", strlen(line), sizeof(line));

  23.   vsnprintf(line + strlen(line), sizeof(line) - strlen(line), fmt, vl);
  24.   fprintf(fp_log, "%s\n", line);

  25.   return;
  26. }

你可能感兴趣的:(Windows Linux可兼容版变长参数的实例程序)