| 
57 | 
The spring docs are great on this: 3.8.1. BeanFactory or ApplicationContext?. They have a table with a comparison, I'll post a snippet: 
Bean Factory 
 
Application Context 
 
So if you need any of the points presented on the Application Context side, you should use ApplicationContext. | ||||||||
| 
 | 
| 
19 | 
To me, the primary difference to choose BeanFactory over ApplicationContext seems to be that ApplicationContext will pre-instantiate all of the beans. From the Spring docs: 
 
Given this, I initially chose BeanFactory for use in integration/performance tests since I didn't want to load the entire application for testing isolated beans. However -- and somebody correct me if I'm wrong -- BeanFactory doesn't support classpath XML configuration. So BeanFactory and ApplicationContext each provide a crucial feature I wanted, but neither did both. 
Near as I can tell, the note in the documentation about overriding default instantiation behavior takes place in the configuration, and it's per-bean, so I can't just set the "lazy-init" attribute in the XML file or I'm stuck maintaining a version of it for test and one for deployment. 
What I ended up doing was extending ClassPathXmlApplicationContext to lazily load beans for use in tests like so:  | ||||||||
| 
 | 

