Skip to content

Latest commit

 

History

History
122 lines (98 loc) · 4.84 KB

bit_and.md

File metadata and controls

122 lines (98 loc) · 4.84 KB

bit_and

  • functional[meta header]
  • std[meta namespace]
  • class template[meta id-type]
  • cpp11[meta cpp]
namespace std {
  // C++11
  template <typename T>
  struct bit_and {
    T operator()(const T& x, const T& y) const;
    using first_argument_type  = T;
    using second_argument_type = T;
    using result_type          = T;
  };

  // C++14 (operator() が constexpr、テンプレート引数にデフォルトが指定された)
  template <typename T = void>
  struct bit_and {
    constexpr T operator()(const T& x, const T& y) const;
    using first_argument_type  = T;
    using second_argument_type = T;
    using result_type          = T;
  };

  template <> // テンプレート引数が void(デフォルト)の場合の特殊化(operator() が関数テンプレート)
  struct bit_and<void> {
    template <typename T, typename U>
    constexpr auto operator()(const T& t, const U& u) const
      -> decltype(forward<T>(t) & forward<U>(u));
    using is_transparent = unspecified;
  };

  // C++20 (first_argument_type, second_argument_type, result_type削除)
  template <typename T = void>
  struct bit_and {
    constexpr T operator()(const T& x, const T& y) const;
  };

  template <> // テンプレート引数が void(デフォルト)の場合の特殊化(operator() が関数テンプレート)
  struct bit_and<void> {
    template <typename T, typename U>
    constexpr auto operator()(const T& t, const U& u) const
      -> decltype(forward<T>(t) & forward<U>(u));
    using is_transparent = unspecified;
  };
}
  • unspecified[italic]
  • forward[link ../utility/forward.md]

概要

bit_andクラスは、ビットごとの論理積(AND)をとる関数オブジェクトである。

この関数オブジェクトは一切のメンバ変数を持たず、状態を保持しない。

メンバ関数

名前 説明 対応バージョン
operator() x & y と等価 C++11

メンバ型

名前 説明 対応バージョン
first_argument_type operator() の最初の引数の型。T と等価(Tvoid 以外の場合のみ) C++11
C++17から非推奨
C++20で削除
second_argument_type operator() の2番目の引数の型。T と等価(Tvoid 以外の場合のみ) C++11
C++17から非推奨
C++20で削除
result_type operator() の戻り値の型。T と等価(Tvoid 以外の場合のみ) C++11
C++17から非推奨
C++20で削除
is_transparent operator() が関数テンプレートである事を示すタグ型。
実装依存の型であるがあくまでタグ型であり、型そのものには意味はない。(Tvoid の場合のみ)
C++14

#include <iostream>
#include <functional>

int main()
{
  // テンプレート引数で operator() の引数の型を指定した書き方(C++11 でも使用可能)
  std::cout << "0x" << std::hex << std::bit_and<int>()(0xFA, 0x47) << std::endl;

  // テンプレート引数で operator() の引数の型を指定しない書き方(C++14 以降で使用可能)
  std::cout << "0x" << std::hex << std::bit_and<>()(0xFA, 0x47) << std::endl;
}
  • std::bit_and[color ff0000]
  • std::hex[link ../ios/hex.md]

出力

0x42
0x42

C++11バージョン

処理系

C++14バージョン

処理系

参照