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 资源锁.通过监视闩锁来确定用户活动和资源使 ...
随机推荐
- banner.txt的图案
根据网上的图片的url生成图片: url的后缀是图片后缀(GIF, JPG, or PNG)才能转换,而像我图片下面的一般不能用(要靠运气,我就成功了) https://www.degraeve.co ...
- Jira使用浅谈篇一
本篇参考: https://www.jianshu.com/u/9dd427d9ad94 Salesforce 生命周期管理(二)Agile & Scrum 浅谈 我们都知道 salesfor ...
- MySQL源码分析之SQL函数执行
1.MySQL中执行一条SQL的总体流程 2.SQL函数执行过程 1.MySQL中执行一条SQL的总体流程 一条包含函数的SQL语句,在mysql中会经过: 客户端发送,服务器连接,语法解析,语句执行 ...
- (WebFlux)003、多数据源R2dbc事务失效分析
一.背景 最近项目持续改造,然后把SpringMVC换成了SpringWebflux,然后把Mybatis换成了R2dbc.中间没有遇到什么问题,一切都那么的美滋滋,直到最近一个新需求的出现,打破了往 ...
- 【java】非常多!学习路径24-总结目前所有知识(上)
感谢sikiedu.com的siki老师.几年前就开始看siki的课程,最近突然想写这个笔记系列,顺便回顾一下这些基础的知识,同时也希望能帮助到一些人,有问题一起交流哈. 全文共十章,大约1.5万字, ...
- VS2017Enterprise版本安装ImageWatch 2017问题解决
按照Andrei给的方法并不一定能成功. 方法如下: 1. Download the extension (ImageWatch.vsix) and open it using WinRAR 2. F ...
- 第七十一篇:Vue组件的私有和全局注册
好家伙, 1.组件的父子关系 我们封装三个组件,分别为left组件,right组件和App组件 在封装时: 在封装时,彼此的关系是独立的,并不存在父子关系 在使用时: 在使用时,根据彼此的嵌套关系,形 ...
- 简述会话跟踪技术——Cookie和Session
简述会话跟踪技术--Cookie和Session 本篇文章将会简单介绍Cookie和Session的概念和用法 会话跟踪技术 首先我们需要搞清楚会话和会话跟踪的概念: 会话:用户打开浏览器,访问Web ...
- Jmeter中的JSON提取器用法
一.使用前提 一般来说JSON提取器只适用于响应结果中返回的是json数据 二.需求 在下一个接口调用上一个接口的数据,如:请求1返回的结果,处理以后作为请求2的参数使用. 首先需要下载JSON Ex ...
- 使用kubectl管理Kubernetes(k8s)集群:常用命令,查看负载,命名空间namespace管理
目录 一.系统环境 二.前言 三.kubectl 3.1 kubectl语法 3.2 kubectl格式化输出 四.kubectl常用命令 五.查看kubernetes集群node节点和pod负载 5 ...