C 语言

关注公众号 jb51net

关闭
首页 > 软件编程 > C 语言 > C++17 std::byte

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

作者: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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文