Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 811695
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 15, 20262026-05-15T01:05:07+00:00 2026-05-15T01:05:07+00:00

Today I had an epiphany, and it was that I was doing everything wrong.

  • 0

Today I had an epiphany, and it was that I was doing everything wrong. Some history: I inherited a C# application, which was really just a collection of static methods, a completely procedural mess of C# code. I refactored this the best I knew at the time, bringing in lots of post-college OOP knowledge. To make a long story short, many of the entities in code have turned out to be Singletons.

Today I realized I needed 3 new classes, which would each follow the same Singleton pattern to match the rest of the software. If I keep tumbling down this slippery slope, eventually every class in my application will be Singleton, which will really be no logically different from the original group of static methods.

I need help on rethinking this. I know about Dependency Injection, and that would generally be the strategy to use in breaking the Singleton curse. However, I have a few specific questions related to this refactoring, and all about best practices for doing so.

  1. How acceptable is the use of static variables to encapsulate configuration information? I have a brain block on using static, and I think it is due to an early OO class in college where the professor said static was bad. But, should I have to reconfigure the class every time I access it? When accessing hardware, is it ok to leave a static pointer to the addresses and variables needed, or should I continually perform Open() and Close() operations?

  2. Right now I have a single method acting as the controller. Specifically, I continually poll several external instruments (via hardware drivers) for data. Should this type of controller be the way to go, or should I spawn separate threads for each instrument at the program’s startup? If the latter, how do I make this object oriented? Should I create classes called InstrumentAListener and InstrumentBListener? Or is there some standard way to approach this?

  3. Is there a better way to do global configuration? Right now I simply have Configuration.Instance.Foo sprinkled liberally throughout the code. Almost every class uses it, so perhaps keeping it as a Singleton makes sense. Any thoughts?

  4. A lot of my classes are things like SerialPortWriter or DataFileWriter, which must sit around waiting for this data to stream in. Since they are active the entire time, how should I arrange these in order to listen for the events generated when data comes in?

Any other resources, books, or comments about how to get away from Singletons and other pattern overuse would be helpful.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-15T01:05:08+00:00Added an answer on May 15, 2026 at 1:05 am

    Alright, here’s my best shot at attacking this question:

    (1) Statics

    The Problem with static that you may be having is that it means different things in .NET and say, C++. Static basically means it’s accessible on the class itself. As for it’s acceptability id say it’s more of something you’d use to do non-instance specific operations on a class. Or just general things like Math.Abs(...). What you should use for a global config is probably a statically accessed property for holding the current/active configuration. Also maybe some static classes for loading/saving setting the config, however the config should be an Object so it can be passed around manipulated, etc.
    public class MyConfiguration
    {
    public const string DefaultConfigPath = “./config.xml”;

      protected static MyConfiguration _current;
      public static MyConfiguration Current
      {
        get
        {
          if (_current == null)
            Load(DefaultConfigPath);
          return _current;
        }
      }
    
      public static MyConfiguration Load(string path)
      {
        // Do your loading here
        _current = loadedConfig;
        return loadedConfig; 
      }
    
      // Static save function
    
      //*********** Non-Static Members *********//
    
      public string MyVariable { get; set; }
      // etc..
    }
    

    (2) Controller/Hardware

    You should probably look into a reactive approach, IObserver<> or IObservable<>, it’s part of the Reactive Framework (Rx).

    Another approach is using a ThreadPool to schedule your polling tasks, as you may get a large number of threads if you have a lot of hardware to pool. Please make sure before using any kind of Threading to learn a lot about it. It’s very easy to make mistakes you may not even realize. This Book is an excelent source and will teach you lots.

    Either way you should probably build services (just a name really) for managing your hardware which are responsible for collecting information about a service (essentially a model-pattern). From there your central controller can use them to access the data keeping the program logic in the controller, and the hardware logic in the service.

    (3) Global Configuration

    I may have touched this subject in point #1 but generally that’s where we go, if you find yourself typing too much you can always pull it out of there assuming the .Instance is an object.

    MyConfiguration cfg = MyConfiguration.Current
    cfg.Foo // etc...
    

    (4) Listening For data

    Again the reactive framework could help you out, or you could build up an event-driven model that uses triggers for incoming data. This will make sure you’re not blocking on a thread till data comes in. It can reduce the complexity of your application greatly.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Today I had to fix some older VB.NET 1.0 code which is using threads.
Today I had the problem that I couldn't delete a folder because it was
So today I had to move some tables with data from an MS Access
A discussion happened today where a grid containing data, which ultimately had data attached
Today I had a coworker suggest I refactor my code to use a label
Today I had a discussion with a colleague about nested functions in Javascript: function
I had an odd problem today when I was trying to serialize an object.
Today I came across a problem where someone had accidentally committed a proj.user file
I had a discussion with a developer earlier today re identifying TCP packets going
Today, I ran into this weird problem with a user using Mac OS X.

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.