Skip to main content

๐ŸŒฑ Spring Boot Interview Series – Q7 ๐Ÿ’ก: Dependency Injection & Bean Management Deep Dive ๐Ÿš€๐Ÿ› ️๐Ÿ“œ

๐ŸŒฑ Spring Boot Interview Series – Q6 ๐Ÿ’ก: Dependency Injection & Bean Management Deep Dive ๐Ÿš€๐Ÿ› ️๐Ÿ“œ


21️⃣ Difference between @Component, @Service, @Repository, and @Controller

Spring Boot uses stereotype annotations to manage beans and organize layers:

  • @Component – Generic annotation for any Spring-managed bean.
  • @Service – Marks service layer classes for business logic.
  • @Repository – Marks DAO layer classes; enables automatic exception translation.
  • @Controller – Handles HTTP requests; used with MVC or REST APIs.

๐Ÿ’ก Real-time Example:

@Repository

public class UserRepository { ... }

@Service

public class UserService {

    @Autowired

    private UserRepository userRepository;

}

22️⃣ Difference between @Bean and @Component

@Component → automatic bean detection via component scanning.

@Bean → explicit bean creation inside a @Configuration class; perfect for third-party classes or custom initialization.

@Configuration

public class AppConfig {

    @Bean

    public PaymentService paymentService() {

        return new CreditCardPaymentService();

    }

}

⚠️ Common mistake: Using @Component on external library classes will not work. Use @Bean instead.

23️⃣ How does @Configuration differ from @Component

@Configuration is a special type of @Component used to declare beans via @Bean methods. Spring ensures singleton beans using CGLIB proxies.

⚠️ Common mistake:

@Component

public class AppConfig {

    @Bean

    public PaymentService paymentService() { ... }

}

This can break singleton guarantees.

24️⃣ What is a Bean definition in Spring Boot

A bean is any object managed by Spring IoC container.

Bean definition = metadata describing the bean: class, scope, dependencies, init/destroy methods. Spring uses this to instantiate and manage lifecycle.

25️⃣ What is bean scope in Spring Boot? Name all scopes

ScopeDescription
singletonDefault, one instance per container
prototypeNew instance each time requested
requestOne instance per HTTP request
sessionOne instance per HTTP session
applicationOne instance per ServletContext
websocketOne instance per WebSocket session

26️⃣ Difference between singleton and prototype bean scope

Singleton beans are shared across the container; prototype beans are new per request.

Singleton → CheckoutService

Prototype → ShoppingCart per user

27️⃣ What is @Primary and when is it used

@Primary resolves ambiguity when multiple beans of the same type exist. Spring injects the primary bean by default.

@Component

@Primary

public class FastPaymentService implements PaymentService {}

28️⃣ How to use @Qualifier to resolve bean conflicts

@Autowired

@Qualifier("fastPaymentService")

private PaymentService paymentService;

๐Ÿ’ก @Primary = default; @Qualifier = explicit selection.

29️⃣ Field injection vs Setter vs Constructor injection

TypeProsCons / Real-time proof
FieldQuick, simpleHard to unit test; could be null outside Spring
SetterTestable, optionalMutable; accidental reassignment possible
ConstructorImmutable, testable, fail-fastMore boilerplate; safest for production

30️⃣ Why constructor injection is recommended

@Component

public class CheckoutService {

    private final PaymentService paymentService;

    @Autowired

    public CheckoutService(PaymentService paymentService) {

        this.paymentService = paymentService;

    }

}

✅ Ensures immutability, fail-fast, unit-testable. ❌ Mistake: making fields public breaks safety.

31️⃣ Can Spring Boot inject values into static fields?

❌ No. Spring injects instance-level fields only.

Workarounds:

  • Use @PostConstruct to assign static fields from instance fields.
  • Prefer singleton beans instead of static injection.

32️⃣ How to load values from application.properties into a bean

@Component

public class AppConfig {

    @Value("${app.name}")

    private String appName;

}

33️⃣ What is @Value used for

Inject property values from application.properties, application.yml, or environment variables. Supports SpEL:

@Value("#{2 * 2}") // injects 4

34️⃣ How to bind a group of properties to a POJO

@Component

@ConfigurationProperties(prefix = "db")

public class DbProperties {

    private String url;

    private String username;

    private String password;

}

๐Ÿ’ก Supports relaxed binding: db-url → dbUrl

35️⃣ How to create a lazy-loaded bean in Spring Boot

@Component

@Lazy

public class RecommendationEngine {

    public RecommendationEngine() {

        System.out.println("ML model loaded!");

    }

}

Real-time scenario: E-commerce recommendation engine only loads when a user opens “Recommended for You”. Saves startup time & memory.

๐ŸŒˆ Wrapping Up

Dependency Injection & Bean Management is the heartbeat of Spring Boot. Key takeaways:

  • Master stereotypes, scopes, injection types.
  • Use constructor injection with final fields for safe, testable, production-ready code.
  • Use @Lazy for heavy or optional beans to optimize startup and memory.
  • Understand @Primary, @Qualifier, @Value, @ConfigurationProperties for real-world apps.

๐Ÿ’ก Interview tip: Use real-time examples like checkout/payment systems, shopping carts, or ML-based recommendations to explain DI concepts. Shows deep understanding beyond syntax!

Comments

Popular posts from this blog

๐Ÿ” Is final Really Final in Java? The Truth May Surprise You ๐Ÿ˜ฒ

๐Ÿ’ฌ “When I was exploring what to do and what not to do in Java, one small keyword caught my eye — final . I thought it meant: locked, sealed, frozen — like my fridge when I forget to defrost it.”   But guess what? Java has its own meaning of final… and it’s not always what you expect! ๐Ÿ˜… Let’s break it down together — with code, questions, confusion, jokes, and everything in between. ๐ŸŽฏ The Confusing Case: You Said It's Final... Then It Changed?! ๐Ÿซ  final List<String> names = new ArrayList <>(); names.add( "Anand" ); names.add( "Rahul" ); System.out.println(names); // [Anand, Rahul] ๐Ÿคฏ Hold on... that’s final , right?! So how on earth is it still changing ? Time to dive deeper... ๐Ÿง  Why Is It Designed Like This? Here’s the key secret: In Java, final applies to the reference , not the object it points to . Let’s decode this like a spy mission ๐Ÿ•ต️‍♂️: Imagine This: final List<String> names = new ArrayList <>(); Be...

๐ŸŒŸ My Journey – From Zero to Senior Java Tech Lead ๐ŸŒŸ

 There’s one thing I truly believe… If I can become a Java developer, then anyone in the world can. ๐Ÿ’ฏ Sounds crazy? Let me take you back. ๐Ÿ•“ Back in 2015… I had zero coding knowledge . Not just that — I had no interest in coding either. But life has its own plans. In 2016, I got a chance to move to Bangalore and joined a Java course at a training center. That’s where it all started — Every day, every session made me feel like: "Ohhh! Even I can be a developer!" That course didn’t just teach Java — it gave me confidence . ๐Ÿงช Two Life-Changing Incidents 1️⃣ The Interview That Wasn't Planned Halfway through my course, I had to urgently travel to Chennai to donate blood to a family member. After that emotional rollercoaster, I found myself reflecting on my skills and the future. The next day, as I was preparing for my move to Bangalore to complete the remaining four months of my course, I randomly thought — "Let me test my skills... let me just see...

๐ŸŽข Java Loops: Fun, Fear, and ForEach() Fails

๐ŸŒ€ Oops, I Looped It Again! — The Ultimate Java Loop Guide You Won't Forget “I remember this question from one of my early interviews — I was just 2 years into Java and the interviewer asked, ‘Which loop do you prefer and why?’” At first, I thought, “Duh! for-each is cleaner.” But then he grilled me with cases where it fails. ๐Ÿ˜ต That led me to explore all loop types, their powers, and their pitfalls. Let’s deep-dive into every major Java loop with examples &  real-world guidance so you'll never forget again. ๐Ÿ” Loop Type #1: Classic For Loop — “The Old Reliable” ✅ When to Use: You need an index You want to iterate in reverse You want full control over loop mechanics ✅ Good Example: List<String> names = List.of("A", "B", "C"); for (int i = 0; i < names.size(); i++) { System.out.println(i + ": " + names.get(i)); } ๐Ÿ”ฅ Reverse + Removal Example: List<String> item...