ThreadStart Delegato
Definizione
Importante
Alcune informazioni sono relative alla release non definitiva del prodotto, che potrebbe subire modifiche significative prima della release definitiva. Microsoft non riconosce alcuna garanzia, espressa o implicita, in merito alle informazioni qui fornite.
Rappresenta il metodo eseguito in un oggetto 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()
- Attributi
Esempio
Nell'esempio di codice seguente viene illustrata la sintassi per la creazione e l'uso di un delegato con un ThreadStart metodo di istanza e con un metodo statico.
Per un altro esempio semplice che illustra come creare un ThreadStart delegato, vedere l'overload del Thread.Start() metodo. Per altre informazioni sulla creazione di thread, vedere Creazione di thread e passaggio di dati all'ora di inizio.
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
Commenti
Quando viene creato un thread gestito, il metodo eseguito nel thread è rappresentato da un delegato o un ThreadStartParameterizedThreadStart delegato passato al Thread costruttore. Il thread non inizia l'esecuzione finché non viene chiamato il Thread.Start metodo. L'esecuzione inizia alla prima riga del metodo rappresentato dal ThreadStart delegato o ParameterizedThreadStart .
Nota
Gli utenti di Visual Basic e C# possono omettere il costruttore o ParameterizedThreadStart delegato durante la ThreadStart creazione di un thread. In Visual Basic usare l'operatore quando si passa il AddressOf
metodo al Thread costruttore, ad esempio Dim t As New Thread(AddressOf ThreadProc)
. In C#, specificare semplicemente il nome della routine thread. Il compilatore seleziona il costruttore delegato corretto.
Per C++, a partire da .NET Framework 2.0, la creazione di un delegato per un ThreadStart metodo statico richiede un solo parametro: l'indirizzo del metodo di callback, qualificato dal nome della classe. Nelle versioni precedenti sono stati necessari due parametri durante la creazione di un delegato per un metodo statico: zero (null) e l'indirizzo del metodo. Per un metodo di istanza, tutte le versioni richiedono due parametri: la variabile di istanza e l'indirizzo del metodo.
Metodi di estensione
GetMethodInfo(Delegate) |
Ottiene un oggetto che rappresenta il metodo rappresentato dal delegato specificato. |