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++免费学习笔记(深入)”;

LangChain
LangChain

一个开源框架,用于构建基于大型语言模型(LLM)的应用程序。

下载
#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中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

css中float用法
css中float用法

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

558

2024.04.28

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

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

98

2025.10.23

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

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

1463

2023.10.24

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

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

228

2024.02.23

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

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

85

2025.10.17

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

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

523

2023.09.20

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

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

122

2023.09.27

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

0

2026.01.15

热门下载

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

精品课程

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

共4课时 | 0.7万人学习

Rust 教程
Rust 教程

共28课时 | 4.4万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

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

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