次の方法で共有


ThreadPool.SetMinThreads(Int32, Int32) メソッド

定義

スレッドがオンデマンドで (新しい要求の発生ごとに) 作成するスレッド プールの数を設定します。この数を超えると、スレッドの作成と破棄を管理するためのアルゴリズムに切り替わります。

public:
 static bool SetMinThreads(int workerThreads, int completionPortThreads);
public static bool SetMinThreads (int workerThreads, int completionPortThreads);
static member SetMinThreads : int * int -> bool
Public Shared Function SetMinThreads (workerThreads As Integer, completionPortThreads As Integer) As Boolean

パラメーター

workerThreads
Int32

スレッド プールがオンデマンドで作成するワーカー スレッドの最小数。

completionPortThreads
Int32

スレッド プールがオンデマンドで作成する非同期 I/O スレッドの最小数。

戻り値

変更が成功した場合は true。それ以外の場合は false

次の例では、ワーカー スレッドの最小数を 4 に設定し、非同期 I/O 完了スレッドの最小数に対して元の値を保持します。

using namespace System;
using namespace System::Threading;
int main()
{
   int minWorker;
   int minIOC;
   
   // Get the current settings.
   ThreadPool::GetMinThreads( minWorker, minIOC );
   
   // Change the minimum number of worker threads to four, but
   // keep the old setting for minimum asynchronous I/O
   // completion threads.
   if ( ThreadPool::SetMinThreads( 4, minIOC ) )
   {
      
      // The minimum number of threads was set successfully.
   }
   else
   {
      
      // The minimum number of threads was not changed.
   }
}
using System;
using System.Threading;

public class Test
{
    public static void Main()
    {
        int minWorker, minIOC;
        // Get the current settings.
        ThreadPool.GetMinThreads(out minWorker, out minIOC);
        // Change the minimum number of worker threads to four, but
        // keep the old setting for minimum asynchronous I/O 
        // completion threads.
        if (ThreadPool.SetMinThreads(4, minIOC))
        {
            // The minimum number of threads was set successfully.
        }
        else
        {
            // The minimum number of threads was not changed.
        }
    }
}
Imports System.Threading

Public Class Test

    <MTAThread> _
    Public Shared Sub Main()
        Dim minWorker, minIOC As Integer
        ' Get the current settings.
        ThreadPool.GetMinThreads(minWorker, minIOC)
        ' Change the minimum number of worker threads to four, but
        ' keep the old setting for minimum asynchronous I/O 
        ' completion threads.
        If ThreadPool.SetMinThreads(4, minIOC) Then
            ' The minimum number of threads was set successfully.
        Else
            ' The minimum number of threads was not changed.
        End If
    End Sub
End Class

注釈

Windows スレッド プールが .NET スレッド プールの代わりに使用されるように構成されている場合、このメソッドはサポートされません。 詳細については、 Windows スレッド プールの構成設定に関するページを参照してください。

スレッド プールは、各カテゴリの最小値に達するまで、新しいワーカー スレッドまたは I/O 完了スレッドをオンデマンドで提供します。 最小値に達すると、スレッド プールはそのカテゴリに追加のスレッドを作成するか、一部のタスクが完了するまで待機できます。 .NET Framework 4 以降、スレッド プールはスループットを最適化するためにスレッドを作成および破棄します。これは、時間単位で完了するタスクの数として定義されます。 スレッドが少なすぎると使用可能なリソースが最適に使用されない可能性があり、スレッドが多すぎるとリソースの競合が増える可能性があります。

要求が少ないときは、スレッド プールの実際のスレッド数が最小値を下回る場合があります。

負の数またはアクティブスレッドプールスレッドの最大数より大きい数を指定した場合(を使用して GetMaxThreads取得) SetMinThreads 、 は を返 false し、どちらの最小値も変更しません。

既定では、スレッドの最小数はプロセッサ数に設定されます。 を使用 SetMinThreads して、スレッドの最小数を増やすことができます。たとえば、キューに置かれている作業項目やタスクによってスレッド プール スレッドがブロックされる問題を一時的に回避できます。 これらのブロックは、すべてのワーカーまたは I/O 完了スレッドがブロック (枯渇) する状況につながる場合があります。 ただし、スレッドの最小数を増やすと、次のような他の方法でパフォーマンスが低下する可能性があります。

  • スレッド プールでは、ワーカー スレッドがブロックされていない場合でも、より多くのワーカー スレッドをスケジュールできます。 オーバーサブスクリプションを使用すると、長いキューで別のタイム スライスが取得されるのを待ち、一部の作業項目またはタスクが遅れるので、スケジュールアウトされるスレッドが大幅に遅延する可能性があります。
  • ワーカー スレッドは、作業を盗むためにより多くのスレッドをスキャンする必要があるため、作業項目のキュー解除に CPU 時間が長くなる可能性があります。
  • スレッド間でコンテキストを切り替えると、CPU 使用率が増加する可能性があります。
  • スレッド スタックのウォークでは、ガベージ コレクションの CPU 時間が長くなる場合があります。
  • このプロセスでは、より多くのメモリが消費される可能性があります。

注意事項

メソッドを SetMinThreads 使用してスレッドの最小数を増やすと、前のテキストで説明したようにパフォーマンスの問題が発生する可能性があります。 ほとんどの場合、スレッド プールは、スレッドを割り当てる独自のアルゴリズムを使用してパフォーマンスが向上します。 最小をプロセッサの数より小さくすると、パフォーマンスが低下する可能性もあります。

適用対象

こちらもご覧ください