C++26 并不存在名为“Circle”的元编程语法;P2590R0 是关于 std::meta 反射 TS 的标准提案,而 Circle 是第三方非标编译器及其私有扩展,二者无隶属关系。C++26 的
Circle 元编程语法(P2590)目前并不存在——它不是已通过、已合并、甚至未进入 TS 的标准提案。
P2590R0 标题是 “std::meta: A Reflection TS for C++26”,它提出的是基于反射(reflection)的元编程设施,而非名为 Circle 的语法。所谓 “Circle” 实际来自第三方编译器 Circle(由 Sean Baxter 开发),它是一个实验性 C++ 前端,自带一套非标准、高度激进的元编程扩展(包括 __meta、__if、__for 等关键字),但这些**完全不属于 ISO C++ 标准**,也不在 P2590 中。
常见混淆点有三个:
std::meta::info、std::meta::get_name 等 API,在 Circle 中有同名但语义不同、行为更激进的对应物(如 __name_of)
它若被采纳,将是 C++ 首次引入**可移植、编译期可用的结构化反射**,核心不是新语法糖,而是新类型与契约:
std::meta::info 是一个不透明的编译期值类型,代表任意声明(类、函数、成员等)的反射信息std::meta::get_members(info) 返回 std::meta::info_sequence,而非宏或模板特化constexpr 函数模拟反射(像 std::is_same_v 那种),而是直接暴露 AST 层信息// P2590 草案风格(非最终语法) constexpr auto cls = std::meta::reflect; for (auto m : std::meta::get_members(cls)) { if (std::meta::is_data_member(m)) { constexpr auto name = std::meta::get_name(m); // 编译期字符串字面量 } }
__meta 扩展不能当 C++26 用如果你在代码里写了 __meta::for_each_member 或 __if (__is_class(T)):
unknown type name '__meta'
__ 前缀关键字或隐式展开Circle 的语法降临;它会靠 std::meta 这类标准库设施,配合已有 constexpr、template 和 Concepts 渐进演进。现在就依赖非标扩展,等于主动把自己锁进单编译器生态——而最常被忽略的一点是:P2590 的反射对象本身不可序列化、不可跨 TU 传递,连 constexpr 函数参数都受限,远比表面看起来更谨慎。