Thread.Start メソッド
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
スレッドの実行をスケジュールします。
オーバーロード
Start() |
オペレーティング システムによって、現在のインスタンスの状態を Running に変更します。 |
Start(Object) |
オペレーティング システムによって現在のインスタンスの状態が Running に変更され、オプションでスレッドが実行するメソッドで使用するデータを格納するオブジェクトが提供されます。 |
Start()
オペレーティング システムによって、現在のインスタンスの状態を Running に変更します。
public:
void Start();
public void Start ();
[System.Runtime.Versioning.UnsupportedOSPlatform("browser")]
public void Start ();
member this.Start : unit -> unit
[<System.Runtime.Versioning.UnsupportedOSPlatform("browser")>]
member this.Start : unit -> unit
Public Sub Start ()
- 属性
例外
スレッドが既に開始されています。
メモリ不足のため、このスレッドを開始できません。
例
次の例では、スレッドを作成して開始します。
using namespace System;
using namespace System::Threading;
public ref class ThreadWork
{
public:
static void DoWork()
{
for ( int i = 0; i < 3; i++ )
{
Console::WriteLine( "Working thread..." );
Thread::Sleep( 100 );
}
}
};
int main()
{
ThreadStart^ myThreadDelegate = gcnew ThreadStart(&ThreadWork::DoWork);
Thread^ thread1 = gcnew Thread( myThreadDelegate );
thread1->Start();
for ( int i = 0; i < 3; i++ )
{
Console::WriteLine( "In main." );
Thread::Sleep( 100 );
}
}
// The example displays output like the following:
// In main.
// Working thread...
// In main.
// Working thread...
// In main.
// Working thread...
using System;
using System.Threading;
public class ThreadWork
{
public static void DoWork()
{
for(int i = 0; i<3;i++) {
Console.WriteLine("Working thread...");
Thread.Sleep(100);
}
}
}
class ThreadTest
{
public static void Main()
{
Thread thread1 = new Thread(ThreadWork.DoWork);
thread1.Start();
for (int i = 0; i<3; i++) {
Console.WriteLine("In main.");
Thread.Sleep(100);
}
}
}
// The example displays output like the following:
// In main.
// Working thread...
// In main.
// Working thread...
// In main.
// Working thread...
Imports System.Threading
Public Class ThreadWork
Public Shared Sub DoWork()
Dim i As Integer
For i = 0 To 2
Console.WriteLine("Working thread...")
Thread.Sleep(100)
Next i
End Sub
End Class
Class ThreadTest
Public Shared Sub Main()
Dim thread1 As New Thread(AddressOf ThreadWork.DoWork)
thread1.Start()
Dim i As Integer
For i = 0 To 2
Console.WriteLine("In main.")
Thread.Sleep(100)
Next
End Sub
End Class
' The example displays output like the following:
' In main.
' Working thread...
' In main.
' Working thread...
' In main.
' Working thread...
注釈
スレッドの状態が終了 ThreadState.Running すると、オペレーティング システムは実行のスケジュールを設定できます。 スレッドコンストラクターに指定された または デリゲートによって表されるメソッドの最初の行で、スレッドの ThreadStart ParameterizedThreadStart 実行が開始されます。 の呼び出しによって Start 呼び出し元のスレッドがブロックされない点に注意してください。
注意
このオーバーロードがデリゲートを使用して作成されたスレッドで使用される場合、 はスレッドによって実行される ParameterizedThreadStart null
メソッドに渡されます。
スレッドが終了したら、 への別の呼び出しでスレッドを再起動することはできません Start
。
こちらもご覧ください
適用対象
Start(Object)
オペレーティング システムによって現在のインスタンスの状態が Running に変更され、オプションでスレッドが実行するメソッドで使用するデータを格納するオブジェクトが提供されます。
public:
void Start(System::Object ^ parameter);
public void Start (object? parameter);
[System.Runtime.Versioning.UnsupportedOSPlatform("browser")]
public void Start (object? parameter);
public void Start (object parameter);
member this.Start : obj -> unit
[<System.Runtime.Versioning.UnsupportedOSPlatform("browser")>]
member this.Start : obj -> unit
Public Sub Start (parameter As Object)
パラメーター
- parameter
- Object
スレッドが実行するメソッドで使用するデータを格納するオブジェクト。
- 属性
例外
スレッドが既に開始されています。
メモリ不足のため、このスレッドを開始できません。
ParameterizedThreadStart デリゲートの代わりに ThreadStart デリゲートを使用して、このスレッドは作成されました。
例
次の例では、静的 ParameterizedThreadStart メソッドとインスタンス メソッドを使用してデリゲートを作成します。
using namespace System;
using namespace System::Threading;
namespace SystemThreadingExample
{
public ref class Work
{
public:
void StartThreads()
{
// Start a thread that calls a parameterized static method.
Thread^ newThread = gcnew
Thread(gcnew ParameterizedThreadStart(Work::DoWork));
newThread->Start(42);
// Start a thread that calls a parameterized instance method.
Work^ someWork = gcnew Work;
newThread = gcnew Thread(
gcnew ParameterizedThreadStart(someWork,
&Work::DoMoreWork));
newThread->Start("The answer.");
}
static void DoWork(Object^ data)
{
Console::WriteLine("Static thread procedure. Data='{0}'",
data);
}
void DoMoreWork(Object^ data)
{
Console::WriteLine("Instance thread procedure. Data='{0}'",
data);
}
};
}
//Entry point of example application
int main()
{
SystemThreadingExample::Work^ samplework =
gcnew SystemThreadingExample::Work();
samplework->StartThreads();
}
// This example displays output like the following:
// Static thread procedure. Data='42'
// Instance thread procedure. Data='The answer.'
using System;
using System.Threading;
public class Work
{
public static void Main()
{
// Start a thread that calls a parameterized static method.
Thread newThread = new Thread(Work.DoWork);
newThread.Start(42);
// Start a thread that calls a parameterized instance method.
Work w = new Work();
newThread = new Thread(w.DoMoreWork);
newThread.Start("The answer.");
}
public static void DoWork(object data)
{
Console.WriteLine("Static thread procedure. Data='{0}'",
data);
}
public void DoMoreWork(object data)
{
Console.WriteLine("Instance thread procedure. Data='{0}'",
data);
}
}
// This example displays output like the following:
// Static thread procedure. Data='42'
// Instance thread procedure. Data='The answer.'
Imports System.Threading
Public Class Work
Shared Sub Main()
' Start a thread that calls a parameterized static method.
Dim newThread As New Thread(AddressOf Work.DoWork)
newThread.Start(42)
' Start a thread that calls a parameterized instance method.
Dim w As New Work()
newThread = New Thread(AddressOf w.DoMoreWork)
newThread.Start("The answer.")
End Sub
Public Shared Sub DoWork(ByVal data As Object)
Console.WriteLine("Static thread procedure. Data='{0}'",
data)
End Sub
Public Sub DoMoreWork(ByVal data As Object)
Console.WriteLine("Instance thread procedure. Data='{0}'",
data)
End Sub
End Class
' This example displays output like the following:
' Static thread procedure. Data='42'
' Instance thread procedure. Data='The answer.'
注釈
スレッドの状態が終了 ThreadState.Running すると、オペレーティング システムは実行のスケジュールを設定できます。 スレッドコンストラクターに指定された または デリゲートによって表されるメソッドの最初の行で、スレッドの ThreadStart ParameterizedThreadStart 実行が開始されます。 の呼び出しによって Start 呼び出し元のスレッドがブロックされない点に注意してください。
スレッドが終了したら、 への別の呼び出しでスレッドを再起動することはできません Start
。
このオーバーロードとデリゲートを使用すると、スレッド プロシージャにデータを簡単に渡できますが、このオーバーロードにはオブジェクトを渡す可能性があります。この手法はタイプ セーフ ParameterizedThreadStart ではありません。 スレッド プロシージャにデータを渡すより堅牢な方法は、スレッド プロシージャとデータ フィールドの両方をワーカー オブジェクトに入れる方法です。 詳細については、「スレッドの作成」 および「開始時刻にデータを渡す」を参照してください。