Skip to content

Latest commit

 

History

History
105 lines (85 loc) · 3.56 KB

common_with.md

File metadata and controls

105 lines (85 loc) · 3.56 KB

common_with

  • concepts[meta header]
  • concept[meta id-type]
  • std[meta namespace]
  • cpp20[meta cpp]
namespace std {
  template<class T, class U>
  concept common_with =
    same_as<common_type_t<T, U>, common_type_t<U, T>> &&
    requires {
      static_cast<common_type_t<T, U>>(declval<T>());
      static_cast<common_type_t<T, U>>(declval<U>());
    } &&
    common_reference_with<
      add_lvalue_reference_t<const T>,
      add_lvalue_reference_t<const U>> &&
    common_reference_with<
      add_lvalue_reference_t<common_type_t<T, U>>,
      common_reference_t<
        add_lvalue_reference_t<const T>,
        add_lvalue_reference_t<const U>>>;
}
  • common_type_t[link /reference/type_traits/common_type.md]
  • add_lvalue_reference_t[link /reference/type_traits/add_lvalue_reference.md]
  • common_reference_with[link /reference/concepts/common_reference_with.md]
  • common_reference_t[link /reference/type_traits/common_reference.md]

概要

common_withは、T, Uの間で、どちらの型からも変換可能な共通の型が存在することを表すコンセプトである。

2つの型T, Uはある型Cへ両方の型から明示的に変換可能な場合にのみ、共通型を持つ。このような型Cは、必ずしもTUと同じ型である必要はなく、Cは一意で無くても良い。

モデル

C = common_type_t<T, U>等しさを保持decltype((t1))decltype((t2))が共にTとなるような式t1, t2及び、等しさを保持しdecltype((u1))decltype((u2))が共にUとなるような式u1, u2について以下の条件を満たす場合に限って、型T, Ucommon_withのモデルである。

  • t1t2が等値である場合にのみ、C(t1)C(t2)も等値となる
  • u1u2が等値である場合にのみ、C(u1)C(u2)も等値となる

備考

このコンセプトをカスタマイズするには、common_typeを利用する。

#include <iostream>
#include <concepts>
#include <vector>
#include <string>

template<typename T, typename U>
requires std::common_with<T, U>
void f() {
  std::cout << "T, U share a common type" << std::endl;
}

template<typename T, typename U>
void f() {
  std::cout << "T, U not share a common type" << std::endl;
}

int main()
{
  f<std::size_t&, int&>();
  f<std::string&, std::string_view&>();
  f<std::vector<int>, std::vector<int>&>();
  f<std::vector<int>, std::vector<double>>();
  f<std::pair<int&, double&>, std::pair<int, double>>();
}
  • std::common_with[color ff0000]

出力

T, U share a common type
T, U share a common type
T, U share a common type
T, U not share a common type
T, U share a common type

バージョン

言語

  • C++20

処理系

関連項目

参照