名前空間
変種
操作

operator==(std::move_only_function)

From cppreference.com
 
 
ユーティリティライブラリ
言語サポート
型のサポート (基本型、RTTI)
ライブラリ機能検査マクロ (C++20)
プログラムユーティリティ
可変引数関数
コルーチンサポート (C++20)
契約サポート (C++26)
三方比較
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

汎用ユーティリティ
関係演算子 (C++20で非推奨)
 
関数オブジェクト
関数の呼び出し
(C++17)(C++23)
恒等関数オブジェクト
(C++20)
透過的な演算子ラッパー
(C++14)
(C++14)
(C++14)
(C++14)  
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)

古いバインダとアダプタ
(C++17まで*)
(C++17まで*)
(C++17まで*)
(C++17まで*)  
(C++17まで*)
(C++17*まで)(C++17*まで)(C++17*まで)(C++17*まで)
(C++20まで*)
(C++20まで*)
(C++17*まで)(C++17*まで)
(C++17*まで)(C++17*まで)

(C++17まで*)
(C++17*まで)(C++17*まで)(C++17*まで)(C++17*まで)
(C++20まで*)
(C++20まで*)
 
 
friend bool operator==( const std::move_only_function& f, std::nullptr_t ) noexcept;
(C++23から)

ラッパーfが呼び出し可能なターゲットを持っているかどうかを、std::nullptr_tとの形式的な比較によってチェックします。空のラッパー(つまり、ターゲットを持たないラッパー)は等しいと評価され、空でない関数は等しくないと評価されます。

この関数は、通常の非修飾または修飾ルックアップからは見えず、std::move_only_function<FunctionType>が引数に関連付けられたクラスである場合にのみ、引数依存の名前探索によって見つけることができます。

!= 演算子は operator== から合成される。

目次

[編集] パラメータ

f - 比較するstd::move_only_function

[編集] 戻り値

!f.

[編集]

#include <functional>
#include <iostream>
#include <utility>
 
using SomeVoidFunc = std::move_only_function<void(int) const>;
 
class C {
public:
    C() = default;
    C(SomeVoidFunc func) : void_func_(std::move(func)) {}
 
    void default_func(int i) const { std::cout << i << '\n'; };
 
    void operator()() const
    {
        if (void_func_ == nullptr) // specialized compare with nullptr
            default_func(7);
        else
            void_func_(7);
    }
 
private:
    SomeVoidFunc void_func_{};
};
 
void user_func(int i)
{
    std::cout << (i + 1) << '\n';
}
 
int main()
{
    C c1;
    C c2(user_func);
    c1();
    c2();
}

出力

7
8

[編集] 関連項目

std::move_only_function がターゲットを持っているかチェックする
(public member function) [編集]
(C++20で削除)
std::functionnullptr を比較します。
(関数テンプレート) [編集]
English 日本語 中文(简体) 中文(繁體)