このページの内容は最新ではありません。最新版の英語を参照するには、ここをクリックします。
MISRA C:2012 Rule 21.3
The memory allocation and deallocation functions of <stdlib.h>
shall not be used
説明
ルール定義
The memory allocation and deallocation functions of <stdlib.h>
shall not be used 1
.
根拠
メモリ割り当ておよび割り当て解除のルーチンを使用すると、未定義の動作が発生する可能性があります。次に例を示します。
動的に割り当てられなかったメモリを解放する。
解放されたメモリの場所を指すポインターを使用する。
Polyspace 実装
チェッカーは、関数 calloc
、malloc
、realloc
、aligned_alloc
、および free
の使用にフラグを設定します。
マクロにこれらの動的ヒープ メモリ割り当て関数と同じ名前を定義して、コード内のマクロを展開する場合、ルールに違反します。ルール 21.2 に違反していないことを前提としています。
レポート内の追加のメッセージ
The macro <name> shall not be used.
Identifier XX should not be used.
トラブルシューティング
ルール違反を想定していてもその違反が表示されない場合、コーディング規約違反が想定どおりに表示されない理由の診断を参照します。
例
チェック情報
グループ: 標準ライブラリ |
カテゴリ: 必要 |
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.