MISRA C:2012 Rule 11.8
A conversion shall not remove any const, volatile or _Atomic qualification from the type pointed to by a pointer
描述
规则定义
A conversion shall not remove any const, volatile or _Atomic qualification from the type pointed to by a pointer 1 .
理由
此规则禁止违反类型修饰符的转换:
将指向
const对象的指针转换为不指向const对象的指针。删除const修饰符后,程序可以修改原本为只读的对象。尝试访问此类转换后的对象可能会导致异常。将指向
volatile对象的指针转换为不指向volatile对象的指针。删除volatile修饰符可以允许编译器在优化期间删除对该对象的访问。将指向
_Atomic对象的指针转换为不指向_Atomic对象的指针。删除_Atomic修饰符后,程序可以绕过对象的锁状态,导致内存损坏。
此类转换违反类型限定。例如,const 修饰符表示对象的只读状态。如果转换删除了限定符,则对象不再为只读。
Polyspace 实现
Polyspace® 标记违反此规则的隐式和显式转换。
故障排除
如果您预期会出现违规,但未看到该违规,请参阅诊断为何编码规范违规未按预期显示。
示例
检查信息
| 组:指针类型转换 |
| 类别:必需 |
| AGC 类别:必需 |
版本历史记录
在 R2014b 中推出1 All MISRA coding rules and directives are © Copyright The MISRA Consortium Limited 2021.
The MISRA coding standards referenced in the Polyspace Bug Finder™ documentation are from the following MISRA standards:
MISRA C:2004
MISRA C:2012
MISRA C:2023
MISRA C++:2008
MISRA C++:2023
MISRA and MISRA C are registered trademarks of The MISRA Consortium Limited 2021.