命名空间
变体
操作

std::ptr_fun

来自 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++11)
关系运算符 (C++20 中已弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型操作
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
通用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
基本字符串转换
(C++17)
(C++17)

 
函数对象
函数调用
(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*)
ptr_fun
(直到 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< class Arg, class Result >

std::pointer_to_unary_function<Arg,Result>

    ptr_fun( Result (*f)(Arg) );
(1) (C++11 中已弃用)
(在 C++17 中移除)
template< class Arg1, class Arg2, class Result >

std::pointer_to_binary_function<Arg1,Arg2,Result>

    ptr_fun( Result (*f)(Arg1, Arg2) );
(2) (C++11 中已弃用)
(在 C++17 中移除)

创建一个函数包装器对象(std::pointer_to_unary_functionstd::pointer_to_binary_function),从模板参数中推断目标类型。

1) 有效地调用 std::pointer_to_unary_function<Arg,Result>(f).
2) 有效地调用 std::pointer_to_binary_function<Arg1,Arg2,Result>(f).

从 C++11 开始,此函数和相关类型已被弃用,取而代之的是更通用的 std::functionstd::ref,它们都可以从普通函数创建可调用适配器兼容的函数对象。

内容

[编辑] 参数

f - 指向要为其创建包装器的函数的指针

[编辑] 返回值

一个包装 f 的函数对象。

[编辑] 异常

可能会抛出实现定义的异常。

[编辑] 示例

#include <algorithm>
#include <functional>
#include <iostream>
#include <string_view>
 
constexpr bool is_vowel(char c)
{
    return std::string_view{"aeoiuAEIOU"}.find(c) != std::string_view::npos;
}
 
int main()
{
    std::string_view s = "Hello, world!";
    std::ranges::copy_if(s, std::ostreambuf_iterator<char>(std::cout),
        std::not1(std::ptr_fun(is_vowel)));
#if 0
// C++11 alternatives:
        std::not1(std::cref(is_vowel)));
        std::not1(std::function<bool(char)>(is_vowel)));
        [](char c) { return !is_vowel(c); });
// C++17 alternatives:
        std::not_fn(is_vowel));
#endif
}

输出

Hll, wrld!

[编辑] 另请参阅

(C++11)
任何可复制构造的可调用对象的复制包装器
(类模板) [编辑]
任何支持限定符的调用签名的可调用对象的移动专用包装器
(类模板) [编辑]
(C++17)(C++23)
使用给定参数调用任何 Callable 对象 并有可能指定返回类型(自 C++23 起)
(函数模板) [编辑]
(C++17)
创建一个函数对象,该对象返回它所持有的函数对象的返回值的补码
(函数模板) [编辑]