0

0

c++中如何使用bit_cast_c++20类型安全位转换方法【实例】

尼克

尼克

发布时间:2026-01-15 13:45:31

|

110人浏览过

|

来源于php中文网

原创

std::bit_cast是C++20引入的类型安全位重解释工具,用于相同大小trivially copyable类型间无损比特复制,可替代reinterpret_cast+memcpy、联合体非法读取和手动memcpy;要求两类型大小相等、均为平凡可复制且启用C++20。

c++中如何使用bit_cast_c++20类型安全位转换方法【实例】

什么是 std::bit_cast,它能替代哪些操作

std::bit_cast 是 C++20 引入的类型安全位重解释工具,用于在两个相同大小的类型之间无损复制底层比特模式。它不是类型转换,不调用构造函数、析构函数或转换运算符,也不涉及指针别名(因此规避了 strict aliasing 问题)。常见替代目标包括:reinterpret_cast + memcpy 组合、联合体(union)的非法读取、以及 std::memcpy 手动实现的位拷贝。

使用 std::bit_cast 的硬性前提和编译要求

必须满足三个条件,否则编译失败:

  • 源类型和目标类型 必须是 trivially copyable(例如 intfloatstd::array,但不能是含虚函数、非平凡构造/析构的类)
  • 源类型与目标类型的 sizeof 必须严格相等(static_assert(sizeof(T) == sizeof(U)) 会触发编译错误
  • 必须启用 C++20 或更高标准(GCC/Clang 需 -std=c++20;MSVC 默认 C++17 不够,需 /std:c++20

例如:std::bit_cast(0x3f800000) 合法;std::bit_cast<:string>(42) 编译报错(std::string 非 trivially copyable);std::bit_cast(1) 报错(sizeof(int) != sizeof(double))。

典型安全用例:浮点与整数互转、字节序无关的序列化

最常见且推荐的用途是 IEEE 754 浮点数与对应宽度整数之间的精确位映射,比如提取 float 的符号/指数/尾数,或构建特定 bit pattern 的 float:

立即学习C++免费学习笔记(深入)”;

Sapling AI Content Detector
Sapling AI Content Detector

Sapling.ai推出的免费在线AI内容检测工具

下载
#include 
#include 

int main() {
    float f = 3.14f;
    auto bits = std::bit_cast(f); // 得到 IEEE 754 表示
    std::cout << std::hex << bits << "\n"; // 输出: 4048f5c3

    uint32_t pattern = 0x4048f5c3;
    float restored = std::bit_cast(pattern);
    // guaranteed same as original f (if no NaN/signaling bit shenanigans)
}

另一个实用场景是跨平台二进制协议中避免依赖 htonl 的手动字节翻转 —— 只要两端都用 std::bit_cast 转成固定大小整数,再按需字节序处理即可。

容易忽略的陷阱:对齐、const、以及 constexpr 上下文限制

std::bit_cast 是 constexpr 函数,但有隐含约束:

  • 若参数是 const 对象,返回值也是 const 类型(不可忽略 cv-qualifiers)
  • 源对象必须满足其对齐要求(例如把 char[4] 的首地址传给 std::bit_cast 时,该地址必须是 alignof(uint32_t) 对齐的,否则行为未定义)
  • 不能用于 volatile 类型(编译器拒绝)
  • 不能在 constexpr 函数中对未初始化内存做 std::bit_cast(如 std::bit_cast(*reinterpret_cast(nullptr)) 即使不执行也会导致 constexpr 失败)

实际编码中,建议始终用数组或 std::array 承载原始字节,再通过 std::bit_cast 转出,这样对齐和生命周期都可控。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

338

2023.08.02

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

571

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

100

2025.10.23

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1489

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

229

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

86

2025.10.17

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

526

2023.09.20

c语言union的用法
c语言union的用法

c语言union的用法是一种特殊的数据类型,它允许在相同的内存位置存储不同的数据类型,union的使用可以帮助我们节省内存空间,并且可以方便地在不同的数据类型之间进行转换。使用union时需要注意对应的成员是有效的,并且只能同时访问一个成员。本专题为大家提供union相关的文章、下载、课程内容,供大家免费下载体验。

125

2023.09.27

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

5

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 12.2万人学习

Rust 教程
Rust 教程

共28课时 | 4.7万人学习

Git 教程
Git 教程

共21课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号