std::unary_function

来自cppreference.com
< cpp‎ | utility‎ | functional
 
 
工具库
类型支持(基本类型、 RTTI 、类型特性)
动态内存管理
错误处理
程序工具
变参数函数
日期和时间
函数对象
(C++11)
关系运算符
optionalanyvariant (C++17)
pair 与 tuple
(C++11)
(C++17)
swap 、 forward 与 move
(C++14)
(C++11)
(C++11)
初等字符串转换
(C++17)
(C++17)
类型运算
(C++11)
(C++17)
 
函数对象
函数包装
(C++11)
(C++11)
(C++17)
绑定
(C++11)
引用包装
(C++11)
(C++11)
运算符包装
取反器
(弃用)
(弃用)

(弃用)
搜索器
旧绑定器与适配器
unary_function
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)

(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
 
定义于头文件 <functional>
template <typename ArgumentType, typename ResultType>
struct unary_function;
(C++11 中弃用)
(C++17 中移除)

unary_function 是用于创建拥有一个参数的函数的基类。

unary_function 不定义 operator() ;它期待导出类定义此运算符。 unary_function 只提供二个类型—— argument_typeresult_type ——为模板形参所定义。

一些标准库函数适配器,如 std::not1 ,要求它们适配的函数对象已定义某些类型; std::not1 要求要适配的函数对象拥有名为 argument_type 的类型。从 unary_function 导出函数对象是令它们与那些适配器兼容的简易方式。

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;
    for (int i = 0; i < 10; ++i) v.push_back(i);
 
    std::cout << std::count_if(v.begin(), v.end(), std::not1(less_than_7()));
 
    /* C++11 解法:
        // 用某方法转型到 std::function<bool (int)> ——即使以 lambda
        std::cout << std::count_if(v.begin(), v.end(),
            std::not1(std::function<bool (int)>([](int i){ return i < 7; }))
        );
    */
}

输出:

3

[编辑] 参阅

(C++11)
包装任何类型的有指定函数调用签名的可调用对象
(类模板) [编辑]
(C++17 前)
从指向函数指针创建适配器兼容的函数对象包装
(函数模板) [编辑]
用于指向一元函数指针的适配器兼容包装
(类模板) [编辑]
(C++17 前)
适配器兼容的二元函数基类
(类模板) [编辑]