メインコンテンツ

MISRA C++:2008 Rule 16-3-1

There shall be at most one occurrence of the # or ## operators in a single macro definition.

説明

ルール定義

There shall be at most one occurrence of the # or ## operators in a single macro definition. 1

根拠

# および ## プリプロセッサ演算子には指定の実行順序がありません。1 つのマクロ定義内に # または ## 演算子が複数出現すると、どのプリプロセッサ演算子がコンパイラによって最初に実行されるものなのかが明確になりません。実行順序の不確かさは、開発者の混乱を招いたり、予期せぬマクロ計算が発生したりする原因となる可能性があります。1 つのマクロ定義に使用する # または ## プリプロセッサ演算子は 1 つのみとしてください。

Polyspace 実装

1 つのマクロ定義に # または ## 演算子が複数含まれている場合、Polyspace® はこの欠陥を報告します。

トラブルシューティング

ルール違反が想定されるものの、Polyspace から報告されない場合は、コーディング規約違反が想定どおりに表示されない理由の診断を参照してください。

すべて展開する

#define STRING(X) { #X }                          //compliant
#define CONCAT(X, Y) {X ## Y}                     //compliant
#define STRING_CONCAT(x, y) {#x ## y}             //noncompliant
#define MULTI_CONCAT(x, y, xy, z) {x ## y ## z}   //noncompliant

マクロ STRING_CONCAT では # 演算子と ## 演算子の両方が使用されているため、Polyspace は非準拠としてこのマクロにフラグを設定します。

マクロ MULTI_CONCAT では複数の ## 演算子が使用されているため、Polyspace は非準拠としてこのマクロにフラグを設定します。

チェック情報

グループ: Preprocessing Directives
カテゴリ: 必要

バージョン履歴

R2013b で導入


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.