さて、私のプログラムには約 30 のスレッドがあり、各スレッドを通じて収集された情報の一部をログに記録する必要があります。
私がこれを行った方法は次のとおりです。 クラス Program で public static StringBuilder を作成すると、各スレッドが数分ごとにこの StringBuilder インスタンスに AppendLine メソッドを呼び出します。次に、30 分ごとに、StreamWriter を使用した書き込み専用の別のスレッドがまさにそれを行います。
例えば:
public class Program
{
public static StringBuilder sb = new StringBuilder();
public static void Main(string[] args)
{
// Start all threads
}
}
public class Example
{
Thread t1 = new Thread(() =>
{
while(true)
{
DoSomething();
}
});
Thread logThread = new Thread(() =>
{
while(true)
{
using(StreamWriter writer = new StreamWriter(Path))
{
writer.Write(Program.sb);
}
}
});
public static void DoSomething()
{
// Will do something for a few minutes.
Program.sb.AppendLine("Some text gathered before...different everytime!");
}
}
これはこれを行う良い方法ですか?
ありがとう