コードインスペクション: パラメーター出力値は常に破棄されます(非 private アクセス)
C# 6.0 の「out var」により、 out パラメーターを持つメソッドの利用に必要なコード量が大幅に削減されました。現在では、ほとんどの場合インラインで変数を宣言し、型推論を利用して多くの場合で変数型も省略しています: dictionary.TryGetValue(key, out var value).
C# 6.0 が改善した out パラメーターの別の側面は、 M(out _) または M(out var _) 構文では不要な出力パラメーター値を無視する機能です。 最新の C# コードベースで DoSomething(arg, out _, out _) のような呼び出しが見られることは珍しくありません。
JetBrains Rider は、そのような呼び出しを分析し、すべての呼び出しサイトで破棄される out パラメーターを報告します。 これは、値が常に破棄される潜在的な問題を特定し、未使用のパラメーターを削除することで署名を簡素化できます。
ソリューション全体のインスペクションを機能させるには、次の少なくとも 1 つを有効にする必要があります。
簡易的なグローバル使用状況チェック: JetBrains Rider 設定 の ページで ソリューション全体の分析がオフの場合に、未使用の非プライベートタイプメンバーを表示する を選択し、 Ctrl+Alt+S を実行します。
ソリューション全体解析: JetBrains Rider 設定 の ページで ソリューション全体の分析を有効化する を選択します Ctrl+Alt+S。
報告されたパラメーターがソリューション内で直接使用されていない場合でも、リフレクションなどによって間接的に使用される場合や、単にパブリック API として設計されている場合もあります。 これらのすべてのケースでは、次のいずれかの方法で、パラメーターの使用状況チェックインスペクションを 抑制する必要があります。
推奨される方法は、暗黙的に使用されるパラメーターを コードアノテーション属性で装飾することです。 この目的のために、 [UsedImplicitly] と [PublicAPI] という属性があり、これらは機能的に類似していますが、チームでパラメーターが実際にどのように使われているかを把握できます。
また、カスタム属性を使用してインスペクションの使用状況を抑制することもできます。 これを行うには、その属性の定義に [MeansImplicitUse] 属性を付けます。
そして最後に、特定の使用チェックインスペクションを、 抑制コメントまたは抑制属性を持つ他のコードインスペクションと同様に抑制することができます。