ReSharper 2018.3ヘルプ

コードの構文スタイル: 暗黙的/明示的な型指定 ('var'キーワード)

C# 3.0で導入された 暗黙的に型指定されたローカル変数 (英語)var キーワードとも呼ばれます)を使用することはかなり可能になりました それは多くのシナリオで読みやすさを向上させるので人気があります。デフォルトでは、ReSharperも var キーワードの使用を推奨しますが、その使用方法の設定は柔軟に設定可能です。たとえば、特定の場合やあらゆる場所で明示的な型を使用することを選択できます。ReSharperを使用すると、設定を強化できます。

C# 7.0から、タプルを分解(英語)するときにローカル変数を宣言できます。そのような宣言で var を好む場合は、結合表記または分離表記を使用するようにスタイルを追加構成することができます。たとえば、 var (x, y) = GetTuple(); または (var x, var y) = GetTuple();です。

C# 7.0のもう1つの機能は破棄です(英語)。これにより、 _という名前のスコープ内の変数と競合しないように var を使用することもできます。ReSharperでは、必要に応じて var を常に破棄して使用するようにスタイルを設定できます。

'var'キーワードの使用の設定を強制する

ReSharperは、すべてのローカル変数を自分の好みに準拠しているかどうかチェックし、そうでない場合、ReSharper はそのような宣言を強調表示し、対応するquick-fixまたは範囲を修正します

デフォルトでは、ReSharperの設定では、'var'キーワードが優先されます:

'Var' usage quick-fix
設定を変更した場合、ReSharperは明示的な型を使用できます:
'Var' usage quick-fix

バルクモードでの 'var'キーワード使用の設定を強制する別のオプションは、コードのクリーンアップです。デフォルトのプロファイルデフォルト: フルクリーンアップコードクリーンアップ実行するか、後述のように特定のタスクのみを対象とするカスタムプロファイルでクリーンアップ実行することができます。

カスタムコードクリーンアッププロファイルで 'var'キーワードを使用する設定を適用するには

  1. メインメニューでReSharper | オプションを選択します。

  2. コードクリーンアップの設定ページコード編集 | コードのクリーンアップに移動します。

  3. 新しいカスタムクリーンアッププロファイルを作成するにはセクションの説明に従って、新しいプロファイルを作成します。新しいプロファイルの選択したプロファイル設定セクションで、'var'キーワードの使用設定を強制するチェックボックスをオンにします。必要に応じて、このプロファイルで他のコードクリーンアップタスクを有効にすることができます。

  4. 保存をクリックして変更を適用し、ReSharperに保存先を選択させるか、次へ保存ドロップダウンリストを使用して特定の設定レイヤーに変更を保存します。詳細については、resharper設定の管理と共有を参照してください。

  5. 設定を適用する範囲を選択します。
    • ファイルの任意の場所にキャレットを設定して、ファイルの設定を強制します。

    • ソリューション・エクスプローラー内の1つまたは複数の項目を選択して、これらのノードおよびその子項目にあるファイルに設定を適用します。

  6. 以下のいずれか 1 つを実行します:
    • Ctrl+Alt+F を押すか、メインメニューからReSharper | 編集 | コードのクリーンアップを選択してください。

    • テキストエディターの任意の場所を右クリックするか、選択項目を右クリックし、コンテキストメニューでコードのクリーンアップを選択します。

  7. 開いているコードクリーンアップダイアログで、新しく作成したプロファイルを選択します。

  8. 実行をクリックします。ReSharperは、選択した範囲であなたの設定を強制します。

コードクリーンアップダイアログを開かずに 'var'キーワードの使用設定を適用する場合は、作成したプロファイルをサイレントクリーンアップにバインドし、 Ctrl+Shift+Alt+Fを押すだけで実行できます。他のコードスタイルのタスクと環境設定を組み合わせるカスタムクリーンアッププロファイルを作成することもできます。

'var'キーワードの設定の設定

'var'キーワードの使用設定は、レイヤーベースの設定の仕組みを使って保存されます。とりわけ、このメカニズムにより、さまざまなソリューションのさまざまな設定を維持したり、これらの設定をVCSに保持したり、チームメンバーと自動的に共有することができます。

'var'キーワードを使用する設定を行うには

  1. ReSharperオプションのコード編集 | C# | コード・スタイルページに移動します。

  2. 宣言における 'var'の使用箇所カテゴリの設定を、コーディングのプラクティス/標準に従って変更します。さまざまなタイプの 'var'または明示的なタイプを使用するためのさまざまな設定を設定できます。
    • ビルトインタイプの場合C#ビルトインタイプ(英語)に適用されます。

    • 単純型の場合 — 総称パラメータのない型に適用されます。

    • 他の場所 — 総称型および分解宣言に適用されます。

    これらの設定のそれぞれに対して、'var'、明示的な型、または明らかなときに 'var'を使用することができます。つまり、オブジェクト、配列、リテラルまたは明示的なキャストの作成として初期化された変数に対してのみ 'var'を使用する必要があります。
  3. デフォルトでは、ReSharperは分解宣言(英語)内の複数の varの結合表記法、例えば var (x, y) = GetTuple();を提案します。 (var x, var y) = GetTuple();のように、展開された変数の宣言を別にすることを選択して別の表記法を選ぶことができます。

  4. デフォルトでは、ReSharperは破棄の(英語)ためにスタンドアロン _ 、例えば (_, _) = (0, 1);を使用することを提案します。廃棄には 'var'キーワードを使用するを選択すると、必要に応じて常に var を破棄して使用することができます。そのため、 _という名前のスコープ内の変数と競合しないようにしてください。

  5. 右側の列の通知するセレクタを使用すると、好みと異なるコードコード・インスペクションの 重大度を設定できます。

  6. 保存をクリックして変更を適用し、ReSharperに保存先を選択させるか、次へ保存ドロップダウンリストを使用して特定の設定レイヤーに変更を保存します。詳細については、resharper設定の管理と共有を参照してください。

また、エディターで 'var'キーワードを使用することの好みを変更することもできます: 該当する問題が強調表示されます:

エディターから 'var'キーワードを使用する設定を変更するには

  1. ReSharperのインスペクションによって強調表示されたコードの問題にキャレットを設定します。

  2. Alt+Enter を押すか、キャレットの左側にあるアクションインジケータをクリックしてアクションリストを開きます。

  3. アクションリストで、インスペクション "推奨する 'var'スタイル" | コードスタイルを設定するに移動して、希望の設定を選択します。

    Changing code style preference for 'var' keyword

  4. 変更はスマートセーブロジックを使用して保存されます。

  5. 変更したスタイル設定を共有設定レイヤーに保存する必要がある場合は、コードスタイルを設定するメニュー項目をクリックするか、 Enter が選択されているときに Enter を押します。ReSharperは、ReSharperオプションのコード編集 | C# | コード・スタイルページを開いて、必要に応じて設定を変更し、次へ保存をクリックして、希望の設定レイヤーを選択します。

この機能は、次の言語とテクノロジでサポートされています。

Language: C#

Language: VB.NET

Language: C++

Language: HTML

Language: ASP.NET

Language: Razor

Language: JavaScript

Language: TypeScript

Language: CSS

Language: XML

Language: XAML

Language: Resx

Language: Build Scripts

Language: Protobuf

Language: JSON

Feature is available

Feature is not available

Feature is not available

Feature is not available

Feature is not available

Feature is not available

Feature is not available

Feature is available

Feature is not available

Feature is not available

Feature is not available

Feature is not available

Feature is not available

Feature is not available

Feature is not available

C#の機能の使用方法については、こちらの説明と例を参照してください。他言語の詳細については、言語によるReSharperの対応するトピックを参照してください。

最終更新日: 2019年2月19日

関連事項