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

转自:http://www.cnblogs.com/cylee025/archive/2011/05/23/2054792.html

 

在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 }

 

程序运行的结果为:

转载于:https://www.cnblogs.com/Androider123/p/3812576.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值