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 资源锁.通过监视闩锁来确定用户活动和资源使 ...
随机推荐
- 在Ubuntu下编译安装GreatSQL
在Ubuntu下编译安装GreatSQL 本次介绍如何利用Docker构建Ubuntu环境,并将GreatSQL源码编译成二进制文件. 1.准备工作 先创建本次Docker的workdir为 /dat ...
- Apache Hudi vs Delta Lake:透明TPC-DS Lakehouse性能基准
1. 介绍 最近几周,人们对比较 Hudi.Delta 和 Iceberg 的表现越来越感兴趣. 我们认为社区应该得到更透明和可重复的分析. 我们想就如何执行和呈现这些基准.它们带来什么价值以及我们应 ...
- 3052 [USACO12MAR]摩天大楼里的奶牛Cows in a Skyscraper (状压DP,IDA*)
状压DP: #include <iostream> #include <cstdio> #include <cstring> #include <algori ...
- 如何在Linux快速搭建一套ADB环境
一.ADB简介 1.什么是ADB Android Debug Bridge,安卓调试桥,它借助adb.exe(Android SDK安装目录platform-tools下),用于电脑端与模拟器或者真实 ...
- Excel 查找函数(二):VLOOKUP
函数讲解 [语法]VLOOKUP(lookup_value, table_array, col_index_num, [range_lookup]) [参数]函数一个有四个参数,其中有三个必填参数:一 ...
- KingbaseES 数据库连接断开问题排查思路
用户在使用数据库过程中,经常会发现如果会话空闲一段时间,会话有可能断开,需要重连.这个问题影响因素很多,包括数据库参数设置.操作系统参数.防火墙等.以下介绍KingbaseES针对该问题的排查思路. ...
- 运维利器-ClusterShell
前言 和ansible类似,但是更加高效 安装 yum install -y clustershell clush命令: clush -a 全部 等于 clush -g all clush -g 指定 ...
- 《吐血整理》进阶系列教程-拿捏Fiddler抓包教程(19)-Fiddler精选插件扩展安装,将你的Fiddler武装到牙齿
1.简介 Fiddler本身的功能其实也已经很强大了,但是Fiddler官方还有很多其他扩展插件功能,可以更好地辅助Fiddler去帮助用户去开发.测试和管理项目上的任务.Fiddler已有的功能已经 ...
- Batch Norm 与 Layer Norm 比较
一.结论 Batch Norm一般用于CV领域,而Layer Norm一般用于NLP领域 Batch Norm需要计算全局平均,而Layer Norm不需要计算全局平均 二.Batch Norm Ba ...
- Mysql阶段性项目——QQ数据库管理
MySql 数据库设计与应用 第七章项目练习 阶段项目--QQ数据库管理 任务概述: 模拟QQ在线聊天系统 后台数据库的创建 基本数据表的创建 表约束. 表间关系的添加 进行数据增加. 删除. 修改. ...