CancelKeyPress イベントが発生しない限り、コンソール アプリケーションを開いたままにしておく最善の方法は何ですか?
入力を受け入れたくないので、 Console.Read または Console.ReadLine を使用しないことをお勧めします。基礎となるアプリケーションが起動されたときにコンソールイベントの詳細を出力できるようにしたいだけです。次に、CancelKeyPress イベントが発生したら、アプリケーションを正常にシャットダウンします。
ここで苦労しているのは「アプリケーションを正常にシャットダウンする」ことだと思います。それ以外の場合、アプリケーションはctrl-cで自動的に終了します。タイトルを変更する必要があります。
これが私があなたが必要だと思うものの簡単なデモです。通知用のロックとモニターを使用すると、もう少し洗練される可能性があります。何が必要かよくわからないので、これをポーズします...
class Program
{
private static volatile bool _s_stop = false;
public static void Main(string[] args)
{
Console.CancelKeyPress += new ConsoleCancelEventHandler(Console_CancelKeyPress);
while (!_s_stop)
{
/* put real logic here */
Console.WriteLine("still running at {0}", DateTime.Now);
Thread.Sleep(3000);
}
Console.WriteLine("Graceful shut down code here...");
//don't leave this... demonstration purposes only...
Console.ReadLine();
}
static void Console_CancelKeyPress(object sender, ConsoleCancelEventArgs e)
{
//you have 2 options here, leave e.Cancel set to false and just handle any
//graceful shutdown that you can while in here, or set a flag to notify the other
//thread at the next check that it's to shut down. I'll do the 2nd option
e.Cancel = true;
_s_stop = true;
Console.WriteLine("CancelKeyPress fired...");
}
}
_s_stopブール値は揮発性として宣言する必要があります。そうしないと、野心的なオプティマイザによってプログラムが無限にループする可能性があります。
_s_stop
ブール値は、コード例で volatile と宣言する必要があります。そうしないと、過度に野心的なオプティマイザーによって、プログラムが無限にループする可能性があります。
アプリケーションを終了する CancelKeyPress にバインドされたハンドラーが既に存在します。これにフックする唯一の理由は、イベントをインターセプトしてアプリが閉じないようにする場合です。
あなたの状況では、アプリを無限ループに入れて、組み込みのイベント ハンドラーで強制終了させてください。Wait(1) やバックグラウンド プロセスなどを使用して、何もしていないときに大量の CPU を使用しないようにすることを検討することをお勧めします。
これはあなたが探しているものかもしれません:
http://msdn.microsoft.com/en-us/library/system.console.cancelkeypress.aspx
CTRL + f5F5(デバッグ)の代わりにキーボードのキーを押して、デバッグなしでプログラムまたはコードを実行するだけです。