C++20中lambda表达式新增加支持的features

      1.弃用通过[=]隐式捕获this,应使用[=,this]或[=,*this]显示捕获

namespace {
struct Foo {
	int x{ 1 };

	void print()
	{
		//auto change1 = [=] { // bad
		auto change1 = [=, this] { // good, this: reference
			this->x = 11;
		};

		change1();
		std::cout << "x: " << x << std::endl; // x: 11

		auto change2 = [=, *this] { // *this: value
			//this->x = 22; // error C3490: 由于正在通过常量对象访问"x",因此无法对其进行修改
			auto m = this->x;
			std::cout << "x: " << x << std::endl; // x: 11
		};

		change2();
	}
};

} // namesapce

int test_lambda_20_this()
{
	Foo foo;
	std::cout << "x: " << foo.x << std::endl; // x: 1
	foo.print();
	std::cout << "x: " << foo.x << std::endl; // x: 11

	return 0;
}

      执行结果如下图所示:

      2.lambda表达式中支持使用模板语法

int test_lambda_20_template()
{
	auto func = []<typename T>(const T& x, const T& y) {
		return (x + y);
	};

	std::cout << "value: " << func(1, 2) << std::endl; // value: 3
	std::cout << "value: " << func(std::string{ "hello " }, std::string{ "world" }) << std::endl; // value: hello world

	return 0;
}

      3.lambda中支持参数包(parameter pack):包括按值捕获参数包和按引用捕获参数包

namespace {
template <typename... Args>
auto func1(Args&&... args)
{
	return [...args = std::forward<Args>(args)] { // by value
		// ...
	};
}

template <typename... Args>
auto func2(Args&&... args) {
	return [&...args = std::forward<Args>(args)] { // by reference
		// ...
	};
}

} // namesapce

int test_lambda_20_parameter_pack()
{
	auto print = [](auto&&... args) {
		((std::cout << args << ' '), ...);
		std::cout << std::endl;
	};

	print(6, 8, "hello, world");

	return 0;
}

      GitHubhttps://github.com/fengbingchun/Messy_Test

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值