ReSharper 2026.1 Help

「スーパークラスの抽出」リファクタリング

このリファクタリングを使用すると、選択したクラスから特定のメンバーを新しい基本クラスに抽出できます。 元のクラスは、作成された基本クラスを拡張します。

現在の型がすでにインターフェースを実装している場合、それらのインターフェースを新しい基本クラスに抽出することもできます。

抽象クラスを作成する場合は、抽出されたメソッド abstract の少なくとも 1 つにマークを付けます。

以下の例では、既存のクラス Circle から抽象クラス Shape を抽出します。

public class Circle : IDrawable { public Point Center { get; private set; } public Color MyColor { get; private set; } public int Radius { get; private set; } public void Draw() { // draw... } } public interface IDrawable { void Draw(); }
public abstract class Shape : IDrawable { public Color MyColor { get; private set; } public abstract void Draw(); } public class Circle : Shape { public Point Center { get; private set; } public int Radius { get; private set; } public override void Draw() { // draw... } } public interface IDrawable { void Draw(); }

基本クラスを抽出する

  1. 次のいずれかの方法でクラスを選択します。

    • エディターで、クラス名にキャレットを置きます。

    • ソリューションエクスプローラーでクラスを選択します。

    • ファイル構造ウィンドウウィンドウでクラスを選択します。

    • クラスビューでクラスを選択します。

    • オブジェクトブラウザーでクラスを選択します。

    • 型依存関係ダイアグラムでクラスを選択します。

  2. 次のいずれかを実行します。

    • Control+Shift+R を押し、を スーパークラスの抽出 を選択します。

    • 右クリックして、コンテキストメニューから リファクタリング | スーパークラスの抽出 を選択します。

    • メインメニューから ReSharper | リファクタリング | 抽出 | スーパークラスの抽出… を選択します。

    スーパークラスの抽出 ダイアログが開きます。

  3. 新しい基本クラスの名前とその配置場所(新しいファイルまたは元の型と同じファイル)を指定します。

  4. 新しい基本クラスに転送するメンバーを選択します。 メンバーのリストには、以下が含まれます。

    • 現在の型のメンバー

    • 選択された型が現在実装しているインターフェース

  5. 個々のメンバーを抽象化 / 保持するには、それらの隣の 抽象化する 列のチェックボックスをオンにします。 抽象とマークされたメンバーが少なくとも 1 つある場合、基本クラスも抽象として作成されます。

  6. すべてのパブリックメンバーをすばやく選択するには、 すべてのパブリック をクリックします。

  7. 他のメンバーを参照するメンバーを選択すると、抽出されたクラスに未定義のシンボルが表示されます。 現在選択されているメンバーに依存するすべてのメンバーを選択して、競合を解決するには、 依存​ をクリックします。

  8. リファクタリングを適用するには、 次へ をクリックします。

  9. 競合するものが見つからない場合、ReSharper はすぐにリファクタリングを実行します。 それ以外の場合は、 競合を解決するように求められます。

ReSharper。 スーパークラス(基底クラス)抽出リファクタリング

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

言語: C#

言語: VB.NET

言語: C++

言語: ASP.NET

言語: Razor

言語: XAML

言語: Resx

言語: スクリプトの作成

言語: SQL

この機能は C# で利用可能です

この機能は Visual Basic で利用可能です

この機能は C++ では使用できません

この機能は ASP.NET では使用できません

この機能は Razor では使用できません

機能は XAML で利用可能です

機能はリソースファイルでは使用できません

機能はビルドスクリプトファイルでは使用できません

機能は SQL/NoSQL ファイルおよびインジェクションでは利用できません

ここで説明する手順と例では、C# の機能の使用について説明します。 他の言語の詳細については、 言語およびフレームワーク セクションの対応するトピックを参照してください。

2026 年 6 月 12 日