std::common_with

< cpp‎ | concepts
定义于头文件 <concepts>
template <class T, class U>

concept common_with =
  std::same_as<std::common_type_t<T, U>, std::common_type_t<U, T>> &&
  requires {
    static_cast<std::common_type_t<T, U>>(std::declval<T>());
    static_cast<std::common_type_t<T, U>>(std::declval<U>());
  } &&
  std::common_reference_with<
    std::add_lvalue_reference_t<const T>,
    std::add_lvalue_reference_t<const U>> &&
  std::common_reference_with<
    std::add_lvalue_reference_t<std::common_type_t<T, U>>,
    std::common_reference_t<
      std::add_lvalue_reference_t<const T>,

      std::add_lvalue_reference_t<const U>>>;
(C++20 起)

概念 common_with<T, U> 指定二个类型 TU 共享均能转换到的共用类型(以 std::common_type_t 计算)。

语义要求

T 与 U 实现 common_with<T, U> ,仅若给定保持相等性的表达式 t1t2u1u2 ,且它们满足 decltype((t1))decltype((t2)) 均为 Tdecltype((u1))decltype((u2)) 均为 U ,且

换言之,转换到共用类型必须保持相等性。

相等性保持

若表达式对给定的相等输入产生相等输出,则它保持相等性

  • 表达式的输入由其操作数组成。
  • 表达式的输出由其结果和表达式所修改的所有操作数(若存在)组成。

在标准概念的规范中,操作数定义为仅包含下列内容的最大子表达式:

每个操作数的 cv 限定与值类别,是通过假设每个模板类型形参代表一个 cv 无限定的非数组对象类型确定的。

进一步要求每个要求保持相等性的表达式都稳定:这种表达式带相同输入对象的二次求值必须拥有相等的输出,而无任何对这些输入对象的显式中间修改。

参阅

确定一组类型的公共类型
(类模板)
确定类型组的共用引用类型
(类模板)
指定两个类型共有一个公共引用类型
(概念)