Csharp-delegates

提供:Dev Guides
移動先:案内検索

C#-デリゲート

C#デリゲートは、CまたはC ++の関数へのポインターに似ています。 delegate は、メソッドへの参照を保持する参照型変数です。 参照は実行時に変更できます。

デリゲートは、特にイベントとコールバックメソッドの実装に使用されます。 すべてのデリゲートは、暗黙的に System.Delegate クラスから派生します。

デリゲートの宣言

デリゲート宣言は、デリゲートが参照できるメソッドを決定します。 デリゲートは、デリゲートと同じ署名を持つメソッドを参照できます。

たとえば、デリゲートを考えます-

public delegate int MyDelegate (string s);

上記のデリゲートを使用して、単一の_string_パラメーターを持ち、_int_型変数を返すメソッドを参照できます。

デリゲート宣言の構文は-

delegate <return type> <delegate-name> <parameter list>

デリゲートのインスタンス化

デリゲートタイプが宣言されたら、デリゲートオブジェクトを new キーワードで作成し、特定のメソッドに関連付ける必要があります。 デリゲートを作成するとき、 new 式に渡される引数はメソッド呼び出しと同様に記述されますが、メソッドへの引数はありません。 たとえば-

public delegate void printString(string s);
...
printString ps1 = new printString(WriteToScreen);
printString ps2 = new printString(WriteToFile);

次の例は、整数パラメーターを受け取り、整数値を返すメソッドを参照するために使用できるデリゲートの宣言、インスタンス化、および使用を示しています。

using System;

delegate int NumberChanger(int n);
namespace DelegateAppl {

   class TestDelegate {
      static int num = 10;

      public static int AddNum(int p) {
         num += p;
         return num;
      }
      public static int MultNum(int q) {
         num *= q;
         return num;
      }
      public static int getNum() {
         return num;
      }
      static void Main(string[] args) {
        //create delegate instances
         NumberChanger nc1 = new NumberChanger(AddNum);
         NumberChanger nc2 = new NumberChanger(MultNum);

        //calling the methods using the delegate objects
         nc1(25);
         Console.WriteLine("Value of Num: {0}", getNum());
         nc2(5);
         Console.WriteLine("Value of Num: {0}", getNum());
         Console.ReadKey();
      }
   }
}

上記のコードをコンパイルして実行すると、次の結果が生成されます-

Value of Num: 35
Value of Num: 175

デリゲートのマルチキャスト

デリゲートオブジェクトは、「+」演算子を使用して構成できます。 構成された代理人は、構成された2人の代理人を呼び出します。 同じタイプの代理人だけが構成できます。 「-」演算子を使用して、合成デリゲートからコンポーネントデリゲートを削除できます。

デリゲートのこのプロパティを使用すると、デリゲートが呼び出されたときに呼び出されるメソッドの呼び出しリストを作成できます。 これは、デリゲートの*マルチキャスト*と呼ばれます。 次のプログラムは、デリゲートのマルチキャストを示しています-

using System;

delegate int NumberChanger(int n);
namespace DelegateAppl {
   class TestDelegate {
      static int num = 10;

      public static int AddNum(int p) {
         num += p;
         return num;
      }
      public static int MultNum(int q) {
         num *= q;
         return num;
      }
      public static int getNum() {
         return num;
      }
      static void Main(string[] args) {
        //create delegate instances
         NumberChanger nc;
         NumberChanger nc1 = new NumberChanger(AddNum);
         NumberChanger nc2 = new NumberChanger(MultNum);

         nc = nc1;
         nc += nc2;

        //calling multicast
         nc(5);
         Console.WriteLine("Value of Num: {0}", getNum());
         Console.ReadKey();
      }
   }
}

上記のコードをコンパイルして実行すると、次の結果が生成されます-

Value of Num: 75

デリゲートを使用する

次の例は、デリゲートの使用方法を示しています。 デリゲート_printString_を使用して、文字列を入力として受け取り、何も返さないメソッドを参照できます。

私たちはこのデリゲートを使用して2つのメソッドを呼び出します。最初のメソッドは文字列をコンソールに出力し、2番目のメソッドはそれをファイルに出力します-

using System;
using System.IO;

namespace DelegateAppl {

   class PrintString {
      static FileStream fs;
      static StreamWriter sw;

     //delegate declaration
      public delegate void printString(string s);

     //this method prints to the console
      public static void WriteToScreen(string str) {
         Console.WriteLine("The String is: {0}", str);
      }

     //this method prints to a file
      public static void WriteToFile(string s) {
         fs = new FileStream("c:\\message.txt",
         FileMode.Append, FileAccess.Write);
         sw = new StreamWriter(fs);
         sw.WriteLine(s);
         sw.Flush();
         sw.Close();
         fs.Close();
      }

     //this method takes the delegate as parameter and uses it to
     //call the methods as required
      public static void sendString(printString ps) {
         ps("Hello World");
      }

      static void Main(string[] args) {
         printString ps1 = new printString(WriteToScreen);
         printString ps2 = new printString(WriteToFile);
         sendString(ps1);
         sendString(ps2);
         Console.ReadKey();
      }
   }
}

上記のコードをコンパイルして実行すると、次の結果が生成されます-

The String is: Hello World