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

  • SEARCH
  • Home
  • 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 742099
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 14, 20262026-05-14T08:42:32+00:00 2026-05-14T08:42:32+00:00

Consider this scenario. I have some business logic that now and then will be

  • 0

Consider this scenario. I have some business logic that now and then will be required to write to a log.

interface ILogger
{
    void Log(string stuff);
}

interface IDependency
{
    string GetInfo();
}

class MyBusinessObject
{
    private IDependency _dependency;

    public MyBusinessObject(IDependency dependency)
    {
        _dependency = dependency;
    }

    public string DoSomething(string input)
    {
        // Process input
        var info = _dependency.GetInfo();
        var intermediateResult = PerformInterestingStuff(input, info);

        if (intermediateResult== "SomethingWeNeedToLog")
        {
            // How do I get to the ILogger-interface?
        }

        var result = PerformSomethingElse(intermediateResult);

        return result;
    }
}

How would you get the ILogger interface? I see two main possibilities;

  1. Pass it using Dependency Injection on the constructor.
  2. Get it via a singleton Service Locator.

Which method would you prefer, and why? Or is there an even better pattern?

Update:
Note that I don’t need to log ALL method calls. I only want to log a few (rare) events that may or may not occur within my method.

  • 1 1 Answer
  • 2 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-14T08:42:33+00:00Added an answer on May 14, 2026 at 8:42 am

    I personally do a mixture of both.

    Here are my conventions:

    • From a static context – Service Location
    • From an instance context – Dependency Injection

    I feel this gives me the right balance of testability. I find it a little harder to setup tests against classes that use Service Location than use DI, so this is why Service Location ends up being the exception rather than the rule. I’m consistent in its use, though, so it’s not hard to remember what type of test I need to write.

    Some have raised the concern that DI tends to clutter constructors. I don’t feel this is a problem, but if you feel this way, there are a number of alternatives that use DI, but avoid constructor parameters. Here is a list of Ninject’s DI methods:
    http://ninject.codeplex.com/wikipage?title=Injection%20Patterns

    You’ll find that most Inversion of Control containers have the same features as Ninject. I chose to show Ninject because they have the most concise samples.

    Hopefully this is helpful.

    Edit: To be clear, I use Unity and Common Service Locator. I have a singleton instance of my Unity container for DI and my implementation of IServiceLocator is simply a wrapper around that singleton Unity container. This way I don’t have to do any type mappings twice or anything like that.

    I also don’t find AOP to be particularly helpful beyond tracing. I like manual logging better simply for its clarity. I know that most AOP logging frameworks are capable of both, but I don’t need the former (AOP’s bread and butter) most of the time. This is just personal preference, of course.

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

Sidebar

Related Questions

Consider this scenario: You have a textbox in which you have to write some
Consider this scenario. I have my own website, that I use as my identifier,
please consider this scenario: we have two web page. a simple page that contains
i have trouble with building some projects. please consider this scenario: i have 2
Please Consider this scenario: We have a base class called clsMain : class clsMain
Consider this scenario. I have an object, lets call it.... Foo. Foo raises a
Consider a grocery store scenario (I'm making this up) where you have FACT records
If we consider a std::string implementation that uses reference counting, consider this scenario: int
Consider this scenario. I have a small enterprise project dev environment. We use archiva
consider this scenario: I have loaded a Parent entity through hibernate Parent contains a

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.