名前空間
変種
操作

std::unary_function

From cppreference.com
< cpp‎ | utility‎ | functional
 
 
ユーティリティライブラリ
言語サポート
型のサポート (基本型、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)

古いバインダとアダプタ
unary_function
(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まで*)
 
ヘッダ <functional> で定義
template< typename ArgumentType, typename ResultType >
struct unary_function;
(C++11で非推奨)
(C++17で削除)

std::unary_function は、単一引数の関数オブジェクトを作成するための基底クラスです。

std::unary_functionoperator() を定義しません。派生クラスがこれを定義することが期待されます。std::unary_function は、テンプレートパラメータによって定義される argument_type および result_type という 2 つの型のみを提供します。

一部の標準ライブラリ関数オブジェクトアダプタ(例: std::not1)は、それがアダプトする関数オブジェクトに特定の型が定義されていることを要求します。std::not1 は、アダプトされる関数オブジェクトに argument_type という名前の型があることを要求します。単一引数を受け取る関数オブジェクトを std::unary_function から派生させることは、それらのアダプタと互換性を持たせるための簡単な方法です。

std::unary_function は C++11 で非推奨となりました。

[編集] メンバ型

定義
argument_type ArgumentType
result_type ResultType

[編集]

#include <algorithm>
#include <functional>
#include <iostream>
#include <vector>
 
struct less_than_7 : std::unary_function<int, bool>
{
    bool operator()(int i) const { return i < 7; }
};
 
int main()
{
    std::vector<int> v(10, 7);
    v[0] = v[1] = v[2] = 6;
 
    std::cout << std::count_if(v.begin(), v.end(), std::not1(less_than_7()));
 
    // C++11 solution:
    // Cast to std::function<bool (int)> somehow - even with a lambda
    // std::cout << std::count_if(v.begin(), v.end(),
    //     std::not1(std::function<bool (int)>([](int i) { return i < 7; })));
}

出力

7

[編集] 関連項目

(C++11)
コピー構築可能な任意の呼び出し可能オブジェクトをラップするコピー可能なラッパー
(クラステンプレート) [編集]
与えられた呼び出しシグネチャで修飾子をサポートする任意の呼び出し可能オブジェクトのムーブ専用ラッパー
(クラステンプレート) [編集]
(C++11で非推奨)(C++17で削除)
関数へのポインタからアダプタ互換の関数オブジェクトラッパーを生成する
(関数テンプレート) [編集]
(C++11で非推奨)(C++17で削除)
単項関数へのポインタ用のアダプタ互換ラッパー
(クラステンプレート) [編集]
(C++11で非推奨)(C++17で削除)
アダプタ互換の二項関数基底クラス
(クラステンプレート) [編集]
English 日本語 中文(简体) 中文(繁體)