C/C++可变参数函数

一、变长参数函数

头文件:#include <stdarg.h>
函数声明

int add(int count, ...);

函数定义

int add(int count, ...)
{
	va_list va;
	va_start(va, count);
	int sum = 0;
	for (int i = 0; i < count; i++)
		sum += va_arg(va, int);
	va_end(va);
	return sum;
}

函数调用

int main()
{
	
	cout<<add(5, 1, 2, 3, 4, 5)<<endl;//输出15
	return 0;
}

二、C++11的新特性,变长参数模板。

    边长参数模板相当于一个模板的递归展开模型,但是它不是递归的。使用的时候,要定义一个“递归”的出口,然后定义一系列的操作,操作的是以“递归”的方式进行的。

递归函数方式展开,模板推导的时候,一层层递归展开,最后到没有参数时用定义的一般函数终止。

void test()
 {
	 cout << "test()" << endl;
 }

 template < class T, class... Args>
 void test(T first, Args... args)
 {
	     cout << typeid(T).name() << " " << first <<endl;
	     test(args...);
 }
test<int, int, long>(1, 2, 3L);
//输出
int 1
int 2
long 3
test()

嗯?第一个test()应该是作为test函数递归调用的结尾。再测试一下

template < class T>
 void test(const T &t)
 {
	 cout << "test()"<<t << endl;
 }

 template < class T, class... Args>
 void test(T first, Args... args)
 {
	     cout << typeid(T).name() << " " << first <<endl;
	     test(args...);
 }
 //输出
int 1
int 2
test()3

这。。。。好像是通过第一个test来控制在哪里结束。

最后写一个正经的累加器:

#include <iostream>
#include <stdarg.h>
using namespace std;
template<typename T>
int add(const T& t)
{
	return t;
}
template<typename T, typename ...Args>
int add(const T& t, const Args&... args) 
{
	return t + add(args...);
}

int main() {
	auto res = add(2, 3, 3);
	std::cout << res << std::endl;
	system("pause");
	return 0;
}
//输出结果 8

三、参考

关于可变参数类模板、右值引用和完美转发的内容可以参考这篇博客https://www.cnblogs.com/kevonyang/p/5932059.html,有时间再研究下后面怎么做。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值