命名空间
变体
操作

std::bit_xor

来自 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*)
(直到 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 T >
struct bit_xor;
(直到 C++14)
template< class T = void >
struct bit_xor;
(自 C++14 起)

用于执行按位异或的函数对象。有效地调用 operator^ 在类型 T 上。

内容

[编辑] 特化

标准库提供了 std::bit_xor 的特化,当 T 未指定时,它会将参数类型和返回值类型推断出来。

函数对象实现 x ^ y 推断参数和返回值类型
(类模板特化) [编辑]
(自 C++14 起)

[编辑] 成员类型

类型 定义
result_type (C++17 中已弃用)(在 C++20 中删除) T
first_argument_type (C++17 中已弃用)(在 C++20 中删除) T
second_argument_type (C++17 中已弃用)(在 C++20 中删除) T

这些成员类型是通过公开继承 std::binary_function<T, T, T> 获得的。

(直到 C++11)

[编辑] 成员函数

operator()
返回两个参数按位异或的结果
(公共成员函数)

std::bit_xor::operator()

T operator()( const T& lhs, const T& rhs ) const;
(自 C++14 起为 constexpr)

返回 lhsrhs 按位异或的结果。

参数

lhs, rhs - 要计算按位异或的值

返回值

lhs ^ rhs 的结果。

[编辑] 异常

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

可能的实现

constexpr T operator()(const T& lhs, const T& rhs) const
{
    return lhs ^ rhs;
}

[编辑] 缺陷报告

以下更改行为的缺陷报告已追溯应用于以前发布的 C++ 标准。

DR 应用于 已发布的行为 正确行为
LWG 660 C++98 缺少用于按位操作的函数对象 已添加