C++泛型lambda配置function的使用

本文介绍了C++14引入的泛型lambda特性,通过一个计算任意类型参数之和的例子展示了其简洁性。泛型lambda简化了成员模板的使用,允许在类中创建并存储这样的可调用对象,如map中的函数对象。此外,还展示了如何在Test类中使用泛型lambda,将其插入到map中,并在成员函数中进行调用,进一步说明了泛型lambda的灵活性。
摘要由CSDN通过智能技术生成

自c++11,c++增加了lambda,这是一个可调用对象,是一个类,匿名类,内部是operator()。

我们先默认各位都熟练使用lambda,下面稍微介绍一下泛型lambda

 在C++14 中引入的泛型lambdas,是一种成员模板的简化。对于一个简单的计算两个任意类
型参数之和的lambda:

[](auto x, auto y) {
	return x + y;
}
*/
//编译器会默认为它构造下面这样一个类:
class SomeCompilerSpecificName {
public:
	SomeCompilerSpecificName(){}; // 构造函数只能由编译器调用
		template<typename T1, typename T2>
	auto operator() (T1 x, T2 y) const {
		return x + y;
	}
};

这非常简单,我们下面看另一段代码

#include<string>
#include<map>
#include<functional>
#include<iostream>

class Test {
public:
	std::map<int, std::function<int(int)>>func;
	int m = 0;

	Test() {
		auto a = [this](auto n) {
			m += 100;
			show();
			return n;
		};
		auto b = [this](auto n) {
			m -= n;
			show();
			return n;
		};
		func.insert(std::make_pair(1, a));
		func.insert(std::make_pair(2, b));
	}

	void test() {
		auto a = [this](auto n) {
			m += 100;
			show();
			return n;
		};
		std::function<std::string(std::string)>f(a);
		auto b = f(std::string("傻子"));
		std::cout << b << std::endl;
	}
private:
	void show() {
		std::cout << this->m << std::endl;
	}
};

int main() {
	Test a;
	a.func[1](100);		//调用函数
	std::cout << a.m << std::endl;

	a.test();		//由此可见,function可以绑定任意的泛型lambda
}

这里只是介绍了泛型lambda在类内与的使用,然后插入到map中。

并无难度

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值