C++ Undefined Behavior 详细列表
Undefined Behavior,即未定义的行为,指程序不可预测的执行效果,一般由错误的代码实现引起。出于效率、兼容性等多方面原因,语言标准不便于定义错误程序的明确行为,而是将其统称为“未定义”的行为,可以是崩溃,也可以是非预期的任意表现,有些问题在编译器和执行环境的特殊处理下也可能不会造成实质性的危害,但不具备可移植性。
《安全规则集合》 是一个研究代码质量和安全措施的项目,本文是其中一个附录,梳理了 ISO/IEC 14882:2003 和 ISO/IEC 14882:2011 前 18 章可导致未定义行为的代码实现方式,后 12 章的主题为标准库实现,相关内容的主旨在前 18 章中已有体现。C 语言相关内容可参见《C 未定义行为成因列表》。
列表
- 代码行以反斜杠结尾,且与下一行连接后生成通用字符名称
- 非空源文件未以换行符结尾,或以换行符结尾但换行符之前是反斜杠
- 连接预处理符号时产生了通用字符名称
- 存在不符合词法的单引号或双引号
- 在 #include 指令中,'、"、\、//、/* 出现在定界符 < > 之间,或 '、\、//、/* 出现在定界符 " 之间
- 无后缀 10 进制整数字面常量超过 long int 取值范围
- 使用非标准转义字符
- 修改字符串字面常量
- 窄字符串与宽字符串连接
- 违反 One Definition Rule
- 具有静态或线程存储期的对象在析构函数中调用 std::exit 函数
- 函数内具有静态或线程存储期的对象已析构,之后该函数又被调用并引用到已析构的对象
- 在对象析构之后使用对象
- 指针指向长度为 0 的内存空间并被解引用
- 内存回收函数抛出异常
- 使用不匹配的方法分配回收资源
- 使用已被释放的指针
- 对象生命周期已结束,但未调用其有副作用的析构函数
- 在分配空间后,生命周期开始前,或在生命周期结束后,回收空间前,通过指针访问对象
- 在分配空间后,生命周期开始前,或在生命周期结束后,回收空间前,通过 glvalue 访问对象
- 具有静态、线程或自动存储期和 non-trivial 析构函数的对象,其空间被非兼容类型的对象占据
- 常量对象的空间或曾属于常量对象的空间被其他对象占据
- 通过 glvalue 访问对象,但 glvalue 的类型不符合要求
- 通过 glvalue 引用不相关类型的对象或未初始化的对象
- 浮点类型转换产生的结果无法在相应的空间中表示
- 浮点类型转为整数类型时,整数类型无法存储浮点类型的整数部分
- 整数类型转为浮点类型时,浮点类型无法存储整数的值
- 表达式求值依赖无确定顺序的副作用
- 表达式的结果在数学上没有定义
- 被调用函数的语言链接性与该函数定义的语言链接性不符
- 将非 POD 对象传入可变参数列表
- 用 static_cast 将基类引用转为派生类引用,基类为虚基类,或引用的实际对象并非派生类对象
- 用 static_cast 将基类指针转为派生类指针,基类为虚基类,或指向的实际对象并非派生类对象
- 用 static_cast 将成员指针转为基类成员指针时,基类中没有相关成员
- 函数指针被转为不兼容的类型并执行
- 类型转换时去掉对象 const 属性并修改对象
- 对不完整类型的对象取地址,但该对象的完整类型重载了 operator &
- new 运算符第一个数组维度的参数为负数
- 用 delete 释放数组漏写中括号,用 delete 释放对象多写中括号,用 delete 释放非 new 表达式的结果
- 被 delete 释放的对象或数组类型不符合要求
- 用 delete 释放不完整类型的对象,但在对象完整类型声明中有 non-trivial 析构函数
- 对象解引用成员指针时,对象的动态类型不包含成员指针引用的成员
- 对象解引用成员指针时,成员指针为空指针
- / 或 % 运算符第二个操作数的值为 0
- 指针加减整数,结果超出了指针所在数组的地址范围
- 不在同一数组中的指针相减
- 移位运算符右操作数为负数或超过相关类型比特位的数量
- 对有符号整数进行超出取值范围的左移运算
- 将对象赋值给具有重叠区域的对象
- 函数没有通过 return 语句返回明确的值,但函数返回值被使用
- 递归地定义和初始化静态对象
- 修改非 mutable 常量对象
- 使用没有 volatile 限定的 glvalue 访问有 volatile 限定的对象
- 具有 noreturn 属性的函数返回至调用方
- 空指针解引用
- 对象的实际类型与当前静态类型不相关,并调用其非静态成员函数
- 在构造函数或析构函数中调用纯虚函数
- 对象的实际类型与当前静态类型不相关,并调用其析构函数
- 在对象生命周期结束后调用其析构函数
- 基类对象构造完毕之前调用成员函数
- 对成员或基类对象的不合理引用
- 将对象指针转为其基类对象的指针时,基类对象尚未开始构造或已结束析构
- 正在构造或析构的对象通过 . 或 -> 调用虚函数,而且该对象与当前构造或析构函数不属于同一个类或基类
- typeid 作用于正在构造或析构的对象,而且该对象与当前构造或析构函数不属于同一个类或基类
- dynamic_cast 作用于正在构造或析构的对象,而且该对象与当前构造或析构函数不属于同一个类或基类
- 需要无限递归的模版实例化
- 构造或析构函数在 function-try-block 的 handler 中访问非静态成员
- 有返回值的函数在 function-try-block 的 handler 中没有正确返回
- 在 #if、 #elif 的条件中,由宏展开产生了 defined 表达式,或 defined 表达式格式不正确
- #include 指令经宏展开后不满足标准格式
- 宏的实参列表中出现预处理指令
- 预处理运算符 # 的结果不是有效的字符串
- 预处理运算符 ## 的结果不是有效的符号
- #line 指定的行号为 0 或大于规定值
- #line 指令不符合标准格式
- 用 #define 定义或用 #undef 取消定义具有保留意义的名称
- 供语言机制调用的函数不符合要求
- 程序实现了应由标准库提供的功能
- 未经许可,向 std 命名空间添加声明或定义
- 对标准库,特化模板类成员函数,特化模板类成员模板函数,特化、偏特化成员类模版
- 未经许可,向 posix 命名空间添加声明或定义
- 声明或定义标准库保留名称
- 编译器未提供标准头文件,但编译时引入了非标准同名头文件
- 为标准库函数提供不符合要求的参数
- 多线程调用标准库函数造成 data race
- 违反标准库函数要求的前置条件,除非标准库函数声明了这种情况会抛出异常
- offsetof 用于非 standard layout 类型,或用于计算静态成员以及成员函数的偏移量
- 可变参数列表省略号左侧的形式参数为函数、数组或引用
- longjmp 跳转使应被执行的析构函数未被执行
C++ Undefined Behavior 详细列表的更多相关文章
- 情景剧:C/C++中的未定义行为(undefined behavior)
写在前面 本文尝试以情景剧的方式,轻松.直观地解释C/C++中未定义行为(undefined behavior)的概念.设计动机.优缺点等内容1,希望读者能够通过阅读本文,对undefined beh ...
- UISearchController Attempting to load the view of a view controller while it is deallocating is not allowed and may result in undefined behavior
Attempting to load the view of a view controller while it is deallocating is not allowed and may res ...
- 【转载】C语言中的undefined behavior/unspecified behavior - 序
嗷嗷的话: 这都是一些细枝末节的东西,我想不做编译器的话,大部分都很难碰到.研究学习这些只是出于对C语言一种偏执狂. 写出来是为了找到和我一样的偏执狂. 在随后的的文章中,首先我写一写191种unde ...
- Response.ContentType 详细列表 <转>
Response.ContentType 详细列表 不同的ContentType 会影响客户端所看到的效果.默认的ContentType为 text/html 也就是网页格式.代码如: <% ...
- WinXP系统服务详细列表
windows XP 系统服务“关闭”详细列表,释放N多内存,128也够用了! 在xp系统中,有近90个服务,默认开启了 30多个服务,而事实上我们只需要其中几个就够用了.禁止所有不必要的服务可以为您 ...
- Oracle_Database_11g_标准版_企业版__下载地址_详细列表
Oracle_Database_11g_标准版_企业版__下载地址_详细列表 Oracle Database 11g Release 2 Standard Edition and Enterprise ...
- SQL Server 2008 R2 性能计数器详细列表(五)
原文:SQL Server 2008 R2 性能计数器详细列表(五) SQL Server:SQL Statistics 对象: 监视编译和发送到 SQL Server 实例的请求类型 SQL Ser ...
- SQL Server 2008 R2 性能计数器详细列表(三)
原文:SQL Server 2008 R2 性能计数器详细列表(三) SQL Server,Deprecated Features 对象: 监视指定为不推荐使用的功能: SQL Server Depr ...
- SQL Server 2008 R2 性能计数器详细列表(四)
原文:SQL Server 2008 R2 性能计数器详细列表(四) SQL Server Latches 对象: 监视称为闩锁的内部 SQL Server 资源锁.通过监视闩锁来确定用户活动和资源使 ...
随机推荐
- 如果让我设计一套,TPS百万级API网关!
作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 是滴,小傅哥又要准备搞事情了!这次准备下手API网关项目,因为这是所有互联网大厂都有的一个核心 ...
- java-集合排序,队列,散列表map以及如何遍历
1.1集合排序 可以通过集合的工具类java.util.Collections的静态方法sort需要注意的时,只能对List排序,因为它有序. Collections.sort(list); 排序字符 ...
- java-正则、object中的两个方法的使用
正则: "."和"\" "."点儿,在正则表达式中表示任意一个字符. "\"在正则表达式中是转意字符,当我们需要描述一个 ...
- Debezium的基本使用(以MySQL为例)
GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. GreatSQL是MySQL的国产分支版本,使用上与MySQL一致. 一.Debezium介绍 摘自官网: Debeziu ...
- Mybatis 懒加载使用及源码分析
Mybatis 懒加载的使用 什么是懒加载?懒加载的意思就是在使用的时候才去加载,不使用不去加载,相反的就叫饥饿加载或者立即加载.懒加载在Mybatis中一般是存在与联合查询的情况,比如查询一个对象的 ...
- 漏洞扫描工具awvs13破解
AWVS13_windows破解版:链接:https://pan.baidu.com/s/1qeGiNubhWgY6oeMx_IkMtg 提取码:2i2o AWVS13_linux破解版:链接:htt ...
- Spring MVC组件之HandlerAdapter
Spring MVC组件之HandlerAdapter HandlerAdapter概述 HandlerAdapter组件是一个处理器Handler的适配器.HandlerAdapter组件的主要作用 ...
- 使用Apache Flink 和 Apache Hudi 创建低延迟数据湖管道
近年来出现了从单体架构向微服务架构的转变.微服务架构使应用程序更容易扩展和更快地开发,支持创新并加快新功能上线时间.但是这种方法会导致数据存在于不同的孤岛中,这使得执行分析变得困难.为了获得更深入和更 ...
- KingbaseES R6 集群禁用 root ssh 后需要修改集群为es_server 案例
案例说明: 在生产环境下,由于安全需要,主机间不允许建立root用户的ssh信任连接,这样导致KingbaseES R6 repmgr集群,通过sys_monitor.sh脚本启动集群时,节点之间不能 ...
- 基于anaconda3的Pytorch环境搭建
安装anaconda3,版本选择新的就行 打开anaconda prompt创建虚拟环境conda create -n pytorch_gpu python=3.9,pytorch_gpu是环境名称, ...