# 3 Inversion of Control

When most developers think of Inversion of Control (also known as Dependency Injection and referred to as such from this point onwards) the Spring Framework comes to mind.

Micronaut takes inspiration from Spring, and in fact, the core developers of Micronaut are former SpringSource/Pivotal engineers now working for OCI.

Unlike Spring which relies exclusively on runtime reflection and proxies, Micronaut uses compile time data to implement dependency injection.

This is a similar approach taken by tools such as Google’s Dagger, which is designed primarily with Android in mind. Micronaut, on the other hand, is designed for building server-side microservices and provides many of the same tools and utilities as Spring but without using reflection or caching excessive amounts of reflection metadata.

The goals of the Micronaut IoC container are summarized as:

• Use reflection as a last resort

• Avoid proxies

• Optimize start-up time

• Reduce memory footprint

• Provide clear, understandable error handling

Note that the IoC part of Micronaut can be used completely independently of Micronaut itself for whatever application type you may wish to build.

To do so all you need to do is configure your build appropriately to include the micronaut-inject-java dependency as an annotation processor.

The easiest way to do this is with Micronaut’s Gradle or Maven plugins. For example with Gradle:

plugins {    id 'io.micronaut.library' version '1.1.0'// <1>}version "0.1"group"com.example"repositories {    mavenCentral()}micronaut {    version ="2.2.3"// <2>}
The entry point for IoC is then the ApplicationContext interface, which includes a run method. The following example demonstrates using it:
Running the ApplicationContext
try(ApplicationContext context =ApplicationContext.run()){(1)MyBean myBean = context.getBean(MyBean.class);(2)// do something with your bean}