@Autowire
适用于大多数场景,当无法满足装配条件时,系统启动将报异常。适用于那些我们自己管理的Bean。-
applicationContext.getBean(name);
适用于手动获取。适用那些最终使用者可能不是我们自己的情况 applicationContext
场景如下
1.做一个公共jar类发布 提供给其他项目组使用的场景
比如我们创建一个公用的包供其它使用者依赖。在这个包中我们自定义了一个接口
Foo
,然后我们自己提供了一个实现类FooImpl
。这时候我们可能需要以下逻辑:如果其它使用者在自己的项目中实现了Foo
接口并注册为Bean
,则使用用户的Bean
,否则使用我们自己的实现类。简单举个日志打印的例子:
我们写的代码如下,最终进行发布,供别人使用:
interface Foo {
void info(String message);
}
class FooImpl {
void info(String message) {
system.out.println(message);
}
}
class Bar {
void test {
Foo foo;
foo = applicationContext.getBean('foo');
foo = foo == null ? new FooImpl() : foo;
foo.info("hello world!");
}
}
然后第一个使用者如果提供了实现了Foo的Bean,则将调用使用者自己定义的:
@Bean public Foo getFoo() { return new 使用者自己的实现类(); }
如果使用者没有自定义实现了Foo的Bean,则将使用我们在前面定义的FooImpl
。
2.项目工程内,通用工具类utils,比如一些时间类,调用类等
既然是工具类,那么使用方法肯定是 类.方法名直接使用,也就是需要静态方法,此时如果需要注入一些service类,就不能用注解了
@Autowired只能在调用自动装配对象的对象的方法不是静态方法时使用,因为静态方法能在对象没实例化时调用,但此时自动装配对象还未装配。
ApplicationContext().getBean()则所用情况都可以使用,尤其在静态方法中,只能用这种方法