C++17中std::byte的具体使用详解

 更新时间:2023年11月27日 13:59:09   作者:fengbingchun  
这篇文章主要为大家详细介绍了C++17中std::byte的具体使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

C++17中std::byte的定义如下:std::byte本质上代表一个字节的值

enum class byte : unsigned char {};

与unsigned char一样,std::byte可以用来访问其它对象(对象表示)占用的原始内存(raw memory),但与unsigned char不同的是,它不是字符类型,也不是算术类型。std::byte模型只是位的集合,仅支持按位和比较操作。

函数std::is_integral_v<T>定义如下:判断T是不是整型,如T为整型,则返回true;如果T的类型为bool、char、char16_t、char32_t、wchar_t、short、int、long、long long,以及任何实现定义的扩展整数类型(any implementation-defined extended integer types),包括任何有符号、无符号、和cv限定的变体(cv-qualified variants),则返回true

template< class T >
inline constexpr bool is_integral_v = is_integral<T>::value;

std::byte相关函数:

(1).std::to_integer<T>(std::byte):将std::byte对象转换为整型T,仅当is_integral_v<T>为true时有效;

(2).左移:<<=, 等价于: b = (std::byte)b << (T)shift; 仅当is_integral_v<T(shift)>为true时有效;

(3).左移:<<,等价于: std::byte(static_cast<unsigned int>(b) << (T)shift); 仅当is_integral_v<T(shift)>为true时有效;

(4).右移:>>=, 等价于: b = (std::byte)b >> (T)shift; 仅当is_integral_v<T(shift)>为true时有效;

(5).右移: >>, 等价于:std::byte(static_cast<unsigned int>(b) >> (T)shift); 仅当is_integral_v<T(shift)>为true时有效;

(6).按位&=、|=、^=:等价于:l = l & r; l = l | r; l = l ^ r;

(7).按位&、|、^、~:等价于:std::byte(static_cast<unsigned int>(l) | static_cast<unsigned int>(r));等

注意:

(1).列表初始化(使用花括号初始化)是唯一可以直接初始化std::byte对象的方法。

(2).std::byte对象存储在栈上。

(3).sizeof(std::byte)的大小总是1.

(4).大多数时候std::byte位数是8,但在有些平台上可能不是。

(5).用std::to_integer<>(std::byte)可以把std::byte转换为任意基本整数类型(bool、字符类型或者整数类型)。

(6).std::byte没有定义输入和输出运算符,因此不得不把它转换为整数类型再进行I/O。

以下为测试代码:

namespace {
 
std::ostream& operator<<(std::ostream& os, std::byte b)
{
    return os << std::bitset<8>(std::to_integer<int>(b));
}
 
} // namespace
 
int test_byte()
{
    // 注意:列表初始化(使用花括号初始化)是唯一可以直接初始化std::byte对象的方法
    std::byte b{ 66 };
    std::cout << b << "\n"; // 01000010
 
    std::byte b2 = b << 1;
    std::cout << b2 << "\n"; // 10000100
    b <<= 1;
    std::cout << b << "\n"; // 10000100
 
    std::byte b3 = b >> 1;
    std::cout << b3 << "\n"; // 01000010
    b >>= 1;
    std::cout << b << "\n"; // 01000010
 
    std::byte b4 = b | std::byte{ 0b11110000 };
    std::cout << b4 << "\n"; // 11110010
    b |= std::byte{ 0b11110000 };
    std::cout << b << "\n"; // 11110010
 
    b4 = b & std::byte{ 0b11110000 };
    std::cout << b4 << "\n"; // 11110000
    b &= std::byte{ 0b11110000 };
    std::cout << b << "\n"; // 11110000
 
    b4 = b ^ std::byte{ 0b11111111 };
    std::cout << b4 << "\n"; // 00001111
    b ^= std::byte{ 0b11111111 };
    std::cout << b << "\n"; // 00001111
 
    b4 = ~b;
    std::cout << b4 << "\n"; // 11110000
 
    std::byte b5;
    //std::cout << b5 << "\n"; // error: 如果没有初始化,std::byte对象的值是未定义的,因为它存储在栈上
 
    std::byte b6{};
    std::cout << b6 << "\n"; // 00000000
 
    std::cout << "sizeof std::byte: " << sizeof(std::byte) << "\n"; // sizeof std::byte: 1
 
    std::byte b7{ 0xFF };
    std::cout << std::to_integer<unsigned int>(b7) << ","
        << std::to_integer<int>(b7) << ","
        << static_cast<int>(std::to_integer<signed char>(b7)) << "\n"; // 255,255,-1
 
    return 0;
}

执行结果如下图所示:

GitHub:https://github.com/fengbingchun/Messy_Test

到此这篇关于C++17中std::byte的具体使用详解的文章就介绍到这了,更多相关C++17 std::byte内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++详细讲解引用类型

    C++详细讲解引用类型

    引用指的是对一个对象的引用。那么什么是对象?在c++中狭义的对象指的是用类,结构,联合等复杂数据类型来声明的变量,如 MyClass myclass,CDialog mydlg,等等
    2022-07-07
  • C++线程间的互斥和通信场景分析

    C++线程间的互斥和通信场景分析

    很多朋友对C++线程间的互斥和通信知识掌握不是多牢靠,今天小编通过模拟车站卖票应用场景给大家详细解析C++线程间的互斥和通信知识,感兴趣的朋友跟随小编一起看看吧
    2021-05-05
  • C++之构造函数默认值设置方式

    C++之构造函数默认值设置方式

    这篇文章主要介绍了C++之构造函数默认值设置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • C/C++中虚基类详解及其作用介绍

    C/C++中虚基类详解及其作用介绍

    这篇文章主要介绍了C/C++中虚基类的详解及其作用介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-09-09
  • C语言 strftime 格式化显示日期时间的实现

    C语言 strftime 格式化显示日期时间的实现

    下面小编就为大家带来一篇C语言 strftime 格式化显示日期时间的实现。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • C语言全面细致讲解单双精度float与double的使用方法

    C语言全面细致讲解单双精度float与double的使用方法

    C语言中小数的数据类型为 float 或 double:float 称为单精度浮点数,double 称为双精度浮点数。不像整数,小数的长度始终是固定的,float 占用4个字节,double 占用8个字节
    2022-05-05
  • qt实现倒计时示例

    qt实现倒计时示例

    这篇文章主要介绍了qt实现倒计时示例,需要的朋友可以参考下
    2014-05-05
  • C++ namespace相关语法实例分析

    C++ namespace相关语法实例分析

    这篇文章主要介绍了C++ namespace相关语法实例分析,对C++初学者有很好的参考借鉴价值,需要的朋友可以参考下
    2014-08-08
  • 基于Matlab实现鲸鱼优化算法的示例代码

    基于Matlab实现鲸鱼优化算法的示例代码

    鲸鱼优化算法(WOA)是澳大利亚学者Mirjaili等于2016年提出的群体智能优化算法,根据座头鲸的捕猎行为实现优化搜索的目的。本文将利用Matlab实现这一算法,需要的可以参考一下
    2022-04-04
  • C++设计模式之外观模式(Facade)

    C++设计模式之外观模式(Facade)

    这篇文章主要为大家详细介绍了C++设计模式之外观模式(Facade),具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03

最新评论