• Class / Function / Type

      std::
    • Header file

      <>
    • Other / All

    最終更新日時(UTC):
    が更新

    履歴 編集

    不明な属性を無視する [P0283R2]

    このページはC++17に採用された言語機能の変更を解説しています。

    のちのC++規格でさらに変更される場合があるため関連項目を参照してください。

    概要

    コンパイラにとって不明な属性は無視する。

    あるコンパイラAで使えるが、別のコンパイラBでは使えない属性を指定したい場合がある。従来はコンパイラが不明な属性を発見したときの振る舞いが明確ではなく、コンパイルエラーが起こる可能性があった。このためコンパイラごとに不明な属性かどうか考慮し、#ifdefなどのマクロで属性を隠す必要があった。

    しかしC++17では不明な属性を無視するように規定されたため、コンパイラごとに不明な属性かどうか考慮する必要はなくなった。

    仕様

    C++標準が定義していない属性かつコンパイラにとって不明な属性は無視する。

    [[deprecated]] void f() {}
      //C++標準に規定されている属性
    
    [[gnu::deprecated]] void g() {}
      //C++標準に規定されていないが、コンパイラにとって既知の属性
      //注意:ClangとGCCでは既知であるが、他のコンパイラでは未知の可能性がある
    
    [[UNKNOWN::unknown_attribute]] void h() {}
      //C++標準に規定されておらず、コンパイラにとって未知の属性
    
    int main() {}
    

    出力

    備考

    Clang++ 5.0.0 にて例に挙げたコードをコンパイルしたとき、未知の属性は無視されるが、同時に下記のように警告も出力される。

    non_standard_attributes.cpp:7:3: warning: unknown attribute 'unknown_attribute' ignored [-Wunknown-attributes]
    [[UNKNOWN::unknown_attribute]] int h() { return 0; }
      ^
    1 warning generated.
    

    プログラマが意図的に未知の属性を指定していて、警告が不要な場合はコンパイラオプションで警告を抑制できる。Clang++の場合は-Wno-unknown-attributesオプション、GCCの場合は-Wno-attributesオプションを指定する。

    関連項目

    参照