ThreadStart 代理人
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
Thread で実行するメソッドを表します。
public delegate void ThreadStart();
public delegate void ThreadStart();
[System.Runtime.InteropServices.ComVisible(true)]
public delegate void ThreadStart();
type ThreadStart = delegate of unit -> unit
[<System.Runtime.InteropServices.ComVisible(true)>]
type ThreadStart = delegate of unit -> unit
Public Delegate Sub ThreadStart()
- 属性
例
次のコード例は、インスタンス メソッドと静的メソッドを使用してデリゲートを ThreadStart 作成および使用するための構文を示しています。
デリゲートを作成する方法を示すもう 1 つの簡単な ThreadStart 例については、 メソッドのオーバーロードに関するページを Thread.Start() 参照してください。 スレッドの作成の詳細については、「 スレッドの作成と開始時のデータの受け渡し」を参照してください。
using namespace System;
using namespace System::Threading;
ref class Work
{
public:
static void DoWork()
{
Console::WriteLine( "Static thread procedure." );
}
int Data;
void DoMoreWork()
{
Console::WriteLine( "Instance thread procedure. Data={0}", Data );
}
};
int main()
{
// To start a thread using an instance method for the thread
// procedure, specify the object as the first argument of the
// ThreadStart constructor.
//
Work^ w = gcnew Work;
w->Data = 42;
ThreadStart^ threadDelegate = gcnew ThreadStart( w, &Work::DoMoreWork );
Thread^ newThread = gcnew Thread( threadDelegate );
newThread->Start();
// To start a thread using a static thread procedure, specify
// only the address of the procedure. This is a change from
// earlier versions of the .NET Framework, which required
// two arguments, the first of which was null (0).
//
threadDelegate = gcnew ThreadStart( &Work::DoWork );
newThread = gcnew Thread( threadDelegate );
newThread->Start();
}
/* This code example produces the following output (the order
of the lines might vary):
Static thread procedure.
Instance thread procedure. Data=42
*/
using System;
using System.Threading;
class Test
{
static void Main()
{
// To start a thread using a static thread procedure, use the
// class name and method name when you create the ThreadStart
// delegate. Beginning in version 2.0 of the .NET Framework,
// it is not necessary to create a delegate explicitly.
// Specify the name of the method in the Thread constructor,
// and the compiler selects the correct delegate. For example:
//
// Thread newThread = new Thread(Work.DoWork);
//
ThreadStart threadDelegate = new ThreadStart(Work.DoWork);
Thread newThread = new Thread(threadDelegate);
newThread.Start();
// To start a thread using an instance method for the thread
// procedure, use the instance variable and method name when
// you create the ThreadStart delegate. Beginning in version
// 2.0 of the .NET Framework, the explicit delegate is not
// required.
//
Work w = new Work();
w.Data = 42;
threadDelegate = new ThreadStart(w.DoMoreWork);
newThread = new Thread(threadDelegate);
newThread.Start();
}
}
class Work
{
public static void DoWork()
{
Console.WriteLine("Static thread procedure.");
}
public int Data;
public void DoMoreWork()
{
Console.WriteLine("Instance thread procedure. Data={0}", Data);
}
}
/* This code example produces the following output (the order
of the lines might vary):
Static thread procedure.
Instance thread procedure. Data=42
*/
Imports System.Threading
Public Class Test
<MTAThread> _
Shared Sub Main()
' To start a thread using a static thread procedure, use the
' class name and method name when you create the ThreadStart
' delegate. Visual Basic expands the AddressOf expression
' to the appropriate delegate creation syntax:
' New ThreadStart(AddressOf Work.DoWork)
'
Dim newThread As New Thread(AddressOf Work.DoWork)
newThread.Start()
' To start a thread using an instance method for the thread
' procedure, use the instance variable and method name when
' you create the ThreadStart delegate. Visual Basic expands
' the AddressOf expression to the appropriate delegate
' creation syntax:
' New ThreadStart(AddressOf w.DoMoreWork)
'
Dim w As New Work()
w.Data = 42
newThread = new Thread(AddressOf w.DoMoreWork)
newThread.Start()
End Sub
End Class
Public Class Work
Public Shared Sub DoWork()
Console.WriteLine("Static thread procedure.")
End Sub
Public Data As Integer
Public Sub DoMoreWork()
Console.WriteLine("Instance thread procedure. Data={0}", Data)
End Sub
End Class
' This code example produces the following output (the order
' of the lines might vary):
'
'Static thread procedure.
'Instance thread procedure. Data=42
注釈
マネージド スレッドが作成されると、スレッドで実行されるメソッドは、コンストラクターに渡されるデリゲートまたはデリゲートによってThreadStart表されますThread。ParameterizedThreadStart メソッドが呼び出されるまで、スレッドの Thread.Start 実行は開始されません。 実行は、 または ParameterizedThreadStart デリゲートによって表されるメソッドの最初の行からThreadStart開始されます。
注意
Visual Basic と C# のユーザーは、スレッドの作成時に ThreadStart または ParameterizedThreadStart デリゲート コンストラクターを省略できます。 Visual Basic では、 メソッドを AddressOf
コンストラクターに渡すときに 演算子を Thread 使用します (例: Dim t As New Thread(AddressOf ThreadProc)
)。 C# では、スレッド プロシージャの名前を指定するだけです。 コンパイラは、適切なデリゲート コンストラクターを選択します。
C++ の場合、.NET Framework 2.0 以降では、静的メソッドのデリゲートを作成するときにThreadStart必要なパラメーターは、コールバック メソッドのアドレス (クラス名で修飾) の 1 つだけです。 以前のバージョンでは、静的メソッドのデリゲートを作成するときに、0 (null) とメソッド アドレスの 2 つのパラメーターが必要でした。 インスタンス メソッドの場合、すべてのバージョンには、インスタンス変数とメソッド アドレスの 2 つのパラメーターが必要です。
拡張メソッド
GetMethodInfo(Delegate) |
指定したデリゲートによって表されるメソッドを表すオブジェクトを取得します。 |
適用対象
こちらもご覧ください
.NET