C/C++中可变参数函数的实现

在C语言的stdarg.h头文件中提供了三个函数va_start, va_end,va_arg和一个类型va_list。利用它们,我们可以很容易实现一个可变参数的函数。首先简单介绍一下这三个函数。

假设现在有一个名为f的函数,其函数定义为:

  
    
void f( int a, int b, ...)

那么,在函数的内部,为了获得这些可变参数,就需要利用到va_start、va_arg和va_end三个函数。

va_list类型的变量可以用于存储可变类型的变量,用它可以对可变变量进行遍历;

  
    
  va_list ap

在使用ap之前,必须调用va_start使得ap和可变参数进行关联;

  
    
va_start(ap, b);

va_start的第二个参数是函数参数列表中最后一个非可变参数的参数;

然后就可以调用va_arg对参数进行访问了;

  
    
type va_arg( ap, type);

在变量处理完成之后,程序结束之前,应该调用va_end一次;

  
    
void va_end(ap);
下面的程序展示了一种可变参数函数和CString::FormatV函数联合使用的技术。该技术在VC++编程中被广泛的使用:
  
    
1 #include < iostream >
2 #include < cstring >
3 #include < string .h >
4 #include < atltime.h >
5
6   using namespace ::std;
7
8   void WriteLogEntry(LPCTSTR pstrFormat, ...)
9 {
10 CTime timeWrite;
11 timeWrite = CTime::GetCurrentTime();
12 CString str = timeWrite.Format(_T( " %d %b %y %H:%M:%S - " ));
13 ATLTRACE(str);
14
15 va_list args;
16 va_start(args, pstrFormat);
17 str.FormatV(pstrFormat, args);
18 ATLTRACE(str);
19 return ;
20 }
21
22   int main()
23 {
24 WriteLogEntry(_T( " Start Program!\n " ));
25 WriteLogEntry(_T( " Program has execute %d lines!\n " ), 201 );
26 WriteLogEntry(_T( " error %d occured at %d line!\n " ), 1170 , 400 );
27 WriteLogEntry(_T( " Program Abouted! " ));
28
29 }

程序运行的结果为:

原创作品,转载请注明出处:http://www.cnblogs.com/cylee025/archive/2011/05/23/2054792.html

你可能感兴趣的:(c/c++)