std::ptr_fun
来自 cppreference.com
< cpp | utility | functional
在头文件中定义 <functional> |
||
template< class Arg, class Result > std::pointer_to_unary_function<Arg,Result> |
(1) | (C++11 中已弃用) (在 C++17 中移除) |
template< class Arg1, class Arg2, class Result > std::pointer_to_binary_function<Arg1,Arg2,Result> |
(2) | (C++11 中已弃用) (在 C++17 中移除) |
创建一个函数包装器对象(std::pointer_to_unary_function 或 std::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::function 和 std::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++23) |
任何支持限定符的调用签名的可调用对象的移动专用包装器 (类模板) |
(C++17)(C++23) |
使用给定参数调用任何 Callable 对象 并有可能指定返回类型(自 C++23 起) (函数模板) |
(C++17) |
创建一个函数对象,该对象返回它所持有的函数对象的返回值的补码 (函数模板) |