#region CPL License /* Nuclex Framework Copyright (C) 2002-2008 Nuclex Development Labs This library is free software; you can redistribute it and/or modify it under the terms of the IBM Common Public License as published by the IBM Corporation; either version 1.0 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the IBM Common Public License for more details. You should have received a copy of the IBM Common Public License along with this library */ #endregion using System; using System.Collections.Generic; using System.Threading; namespace Nuclex.Support.Scheduling { /// Operation that executes a method in a background thread public abstract class ThreadOperation : Operation { /// /// Initializes a new threaded operation. /// /// /// Uses a ThreadPool thread to execute the method in a background thread. /// public ThreadOperation() : this(true) { } /// /// Initializes a new threaded operation which optionally uses the ThreadPool. /// /// Whether to use a ThreadPool thread. /// /// If useThreadPool is false, a new thread will be created. This guarantees /// that the method will be executed immediately but has an impact on /// performance since the creation of new threads is not a cheap operation. /// public ThreadOperation(bool useThreadPool) { this.useThreadPool = useThreadPool; } /// Launches the background operation public override void Begin() { if(useThreadPool) { ThreadPool.QueueUserWorkItem(callMethod); } else { Thread thread = new Thread(callMethod); thread.Name = "Nuclex.Support.Scheduling.ThreadOperation"; thread.IsBackground = true; thread.Start(); } } /// Contains the payload to be executed in the background thread protected abstract void Execute(); /// Invokes the delegate passed as an argument /// Not used private void callMethod(object state) { try { Execute(); } catch(Exception exception) { SetException(exception); } finally { OnAsyncEnded(); } } /// Whether to use the ThreadPool for obtaining a background thread private bool useThreadPool; } } // namespace Nuclex.Support.Scheduling