MVVM and avoiding Monolithic God object

Posted by bufferz on Stack Overflow See other posts from Stack Overflow or by bufferz
Published on 2010-06-01T15:59:41Z Indexed on 2010/06/01 16:03 UTC
Read the original article Hit count: 239

Filed under:
|
|
|

I am in the completion stage of a large project that has several large components: image acquisition, image processing, data storage, factory I/O (automation project) and several others.

Each of these components is reasonably independent, but for the project to run as a whole I need at least one instance of each component. Each component also has a ViewModel and View (WPF) for monitoring status and changing things.

My question is the safest, most efficient, and most maintainable method of instantiating all of these objects, subscribing one class to an Event in another, and having a common ViewModel and View for all of this.

Would it best if I have a class called God that has a private instance of all of these objects? I've done this in the past and regretted it.

Or would it be better if God relied on Singleton instances of these objects to get the ball rolling.

Alternatively, should Program.cs (or wherever Main(...) is) instantiate all of these components, and pass them to God as parameters and then let Him (snicker) and His ViewModel deal with the particulars of running this projects.

Any other suggestions I would love to hear.

Thank you!

© Stack Overflow or respective owner

Related posts about c#

Related posts about wpf