ReSharper 2018.2ヘルプ

フィールドを読み取り専用にする

It is often reasonable to use the 'readonly'修飾子(英語) for fields that are assigned in the declaration or in a constructor and only have read usages. By default, ReSharper suggests that you make a field readonly if the above conditions are met. It highlights such fields and suggests the corresponding quick-fix or fix in scope:

Make field readonly quick-fix

If you do not want ReSharper to suggest this, you can disable the code inspection that detects it ( フィールドは読み取り専用にすることができます ).

逆の機能も利用できます: コード内の後でreadonlyフィールドを変更すると(コンパイラエラーにつながる)、ReSharperはエラーを検出し、フィールドから 'readonly'キーワードを削除して修正を提案します:

Make non-readonly fix

Another option to make fields readonly in a bulk mode is code cleanup. You can either run code cleanup with the default profile デフォルト: フルクリーンアップ or run the cleanup with a custom profile solely targeted at your specific task as described below.

読み取り専用のフィールドに 'readonly'キーワードを追加するには

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

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

  3. 新しいカスタムクリーンアッププロファイルを作成するにはセクションの説明に従って、新しいプロファイルを作成します。新しいプロファイルの選択したプロファイル設定セクションで、可能であれば、フィールドを読み取り専用にするチェックボックスをオンにします。必要に応じて、このプロファイルで他のコードクリーンアップタスクを有効にすることができます。

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

  5. フィールドを読み取り専用にするスコープを選択します。
    • ファイル内のどこにでもキャレットを設定して、フィールドをファイルの読み込み専用にします。

    • ソリューション・エクスプローラーの1つまたは複数の項目を選択して、これらのノードおよびその子項目のファイルでフィールドを読み取り専用にします。

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

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

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

  8. 実行をクリックします。ReSharperは、選択した範囲でフィールドを読み取り専用にします。

If you want to make fields readonly without opening the コードクリーンアップダイアログ , you can bind the created profile to the silent cleanup and run it simply by pressing Ctrl+Shift+Alt+F . You can also create a custom cleanup profile that would combine making fields readonly with other code style tasks.

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

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 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

Feature is not available

最終更新日: 2018年11月28日

関連事項