これはすでに質問されていることは知っていますが、解決策が見つかりませんでした。これが私のサービスです。
class Program : ServiceBase
{
private Timer _timer;
public Program()
{
ServiceName = "PrintTime";
}
static void Main(string[] args)
{
Run(new Program());
}
protected override void OnStart(string[] args)
{
base.OnStart(args);
_timer = new Timer(5000);
_timer.Elapsed += _timer_Elapsed;
_timer.Start();
}
void _timer_Elapsed(object sender, ElapsedEventArgs e)
{
WriteTimeToFile();
}
protected override void OnStop()
{
_timer.Stop();
}
private void WriteTimeToFile()
{
using (FileStream fs = new FileStream(@"d:\mylog.txt", FileMode.Append, FileAccess.ReadWrite))
{
StreamWriter streamWriter = new StreamWriter(fs);
streamWriter.Write(DateTime.Now.ToShortTimeString());
streamWriter.Close();
fs.Close();
}
}
}
ご覧のとおり、5秒ごとにファイルに書き込みたいのですが、2分経っても何も起こりませんcurrentTime
。関数をメソッドMylog.txt
に入れると、正常に機能しますが、タイマーでは機能しません。WriteTimeToFile()
OnStart
どんな助けでも大歓迎です。