Proper way to Dispose of a BackGroundWorker

后端 未结 5 1728
既然无缘
既然无缘 2020-11-28 11:44

Would this be a proper way to dispose of a BackGroundWorker? I\'m not sure if it is necesary to remove the events before calling .Dispose(). Also is calling .Dispose() ins

相关标签:
5条回答
  • 2020-11-28 12:03

    BackgroundWorker derives from Component. Component implements the IDisposable interface. That in turn makes BackgroundWorker inherit the Dispose() method.

    Deriving from Component is a convenience for Windows Forms programmers, they can drop a BGW from the toolbox onto a form. Components in general are somewhat likely to have something to dispose. The Windows Forms designer takes care of this automatically, look in the Designer.cs file for a Form for the "components" field. Its auto-generated Dispose() method calls the Dispose() method for all components.

    However, BackgroundWorker doesn't actually have any member that requires disposing. It doesn't override Dispose(). Its base implementation, Component.Dispose(), only makes sure that the component is removed from the "components" collection. And raise the Disposed event. But doesn't otherwise dispose anything.

    Long story short: if you dropped a BGW on a form then everything is taken care of automatically, you don't have to help. If you didn't drop it on a form then it isn't an element in a components collection and nothing needs to be done.

    You don't have to call Dispose().

    0 讨论(0)
  • 2020-11-28 12:04

    Late to the game, but I just ran across a scenario related to your question that I thought I would share. If you create your worker at the class level and reuse it on successive operations without closing the app, if you don't remove the events after completion they will increment and run multiple times on each successive execution.

    worker.RunWorkerCompleted -= new RunWorkerCompletedEventHandler(worker_RunWorkerCompleted);
    worker.DoWork -= new DoWorkEventHandler(worker_DoWork);
    

    Without the above my DoWork fires once the first time, twice the second time, etc. This is probably a no-brainer for most, but it took me a bit to figure it out, so hopefully this will help someone else out.

    0 讨论(0)
  • 2020-11-28 12:06

    Yes, this appears proper. Of course, disposable objects are better handled with using blocks, but you don't have that option here.

    I usually create my background handers with form lifetimes, reuse them, and let the designer code handle disposal on form close. Less to think about.

    0 讨论(0)
  • 2020-11-28 12:12

    worker.Dispose() is not required, because Dispose() is automatically called. But before disposing the object you need to remove all events handlers.

    This article informs us about this.

    worker.RunWorkerCompleted -= new RunWorkerCompletedEventHandle(worker_RunWorkerCompleted);
    worker.DoWork -= new DoWorkEventHandler(worker_DoWork);
    
    0 讨论(0)
  • 2020-11-28 12:25

    If it's on a "WinForms" Form let the container take care of it (see the generated Dispose code in the Form.Designer.xyz file)

    In practice I have found that you may need to create an instance of the container and add the worker (or other companent) to it, if anyone knows a more official way to do this yell out!!

    PK :-)

    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
    
            // watch the disposed event....
            backgroundWorker1.Disposed += new EventHandler(backgroundWorker1_Disposed);
    
            // try with and without the following lines
            components = new Container();
            components.Add(backgroundWorker1);
        }
    
        void backgroundWorker1_Disposed(object sender, EventArgs e)
        {
            Debug.WriteLine("backgroundWorker1_Disposed");
        }
    
    //... from the Designer.xyz file ...
    
        /// <summary>
        /// Clean up any resources being used.
        /// </summary>
        /// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
        protected override void Dispose(bool disposing)
        {
            if (disposing && (components != null))
            {
                components.Dispose();
            }
            base.Dispose(disposing);
        }
    
    }
    
    0 讨论(0)
提交回复
热议问题