0

0

C++标准库替代方案:GSL(Guidelines Support Library)使用指南【微软推荐】

冰火之心

冰火之心

发布时间:2026-01-18 11:27:22

|

237人浏览过

|

来源于php中文网

原创

GSL是补足标准库安全缺口的轻量工具集,提供gsl::at()越界检查、gsl::narrow()截断防护、gsl::not_null空指针编译期拦截,但需启用C++ Core Guidelines检查器才能发挥预警作用。

c++标准库替代方案:gsl(guidelines support library)使用指南【微软推荐】

GSL 不是“替代”标准库,而是帮你更安全地用好标准库的轻量工具集——它不提供新容器或算法,只补足边界检查、空指针防护、类型转换等关键安全缺口。

什么时候该用 gsl::at() 而不是 operator[]

当你在循环里用非常量索引访问 std::vectorstd::array 或原生数组时,operator[] 完全不检查越界,而编译器(尤其开启 MSVC 的 C++ Core Guidelines 检查)会直接报 C26446 警告。

  • ✅ 安全写法:gsl::at(vec, i)vec.at(i) —— 两者都抛 std::out_of_range,但 gsl::at 对原生数组也有效
  • ❌ 危险写法:vec[i]i 是变量)、arr[i]arrint arr[10]
  • ⚠️ 注意:std::string_viewoperator[] 同样不安全,也需改用 gsl::at(sv, i)
#include 
#include 
std::vector v = {1, 2, 3};
int x = gsl::at(v, 5); // 运行时报 std::out_of_range,而非未定义行为

如何避免 static_cast 引发的静默截断?用 gsl::narrowgsl::narrow_cast

比如把 uint32_t 拆成三个 uint8_t 像素值时,static_cast 不报错,但高位非零会导致数据丢失——C26472 就是为此而设。

  • gsl::narrow(v >> 16):严格检查,越界则抛 gsl::narrowing_error
  • gsl::narrow_cast(v & 0xFF):明确承认可能丢数据,且你已确认安全
  • ❌ 不要用 static_cast(v) 替代,尤其在处理外部输入或计算中间值时
auto rgb_from_24bit(uint32_t v) noexcept {
    return std::array{
        gsl::narrow(v >> 16),   // 安全:高位必须为 0
        gsl::narrow_cast((v >> 8) & 0xFF), // 显式接受低位截断
        gsl::narrow_cast(v & 0xFF)
    };
}

为什么 gsl::not_null 比 “加个注释说不能传 nullptr” 强得多

它把空指针检查从运行时提前到编译期,且对裸指针、智能指针、自定义句柄都统一支持。一旦传入 nullptr,连编译都过不去。

企奶奶
企奶奶

一款专注于企业信息查询的智能大模型,企奶奶查企业,像聊天一样简单。

下载

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

  • ✅ 函数参数强制非空:void draw(gsl::not_null s),调用 draw(nullptr) 直接报错
  • ✅ 支持智能指针:gsl::not_null<:shared_ptr>>,避免 make_shared() 返回空的误用
  • ⚠️ 注意:gsl::not_null 是零开销抽象(无成员变量),但构造时若传入空指针,行为是未定义(所以务必靠编译器拦截)
void process(gsl::not_null p) {
    *p = 42; // 编译器保证 p != nullptr,可放心解引用
}
int x = 0;
process(&x);     // ✅ OK
// process(nullptr); // ❌ 编译失败

真正容易被忽略的是:GSL 的安全机制只在你「主动启用」时才起作用——MSVC 需开启 C++ Core Guidelines 规则集,Clang/GCC 则依赖静态分析工具(如 clang-tidy 的 cppcoreguidelines-* 规则)。不配置检查器,gsl::atgsl::narrow 依然能用,但警告不会自动出现,等于关掉了最重要的哨兵。

相关专题

更多
java基础知识汇总
java基础知识汇总

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

1465

2023.10.24

string转int
string转int

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

318

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

538

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

52

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

197

2025.08.29

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

175

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

97

2025.11.27

空指针异常处理
空指针异常处理

本专题整合了空指针异常解决方法,阅读专题下面的文章了解更多详细内容。

22

2025.11.16

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.8万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

ASP 教程
ASP 教程

共34课时 | 3.7万人学习

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

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