[TOC]
# 导入新的约束
在spring中使用注解,我们必须在applicationContext.xml文件中添加一个标签
`<context:annotation-config/>`作用是让spring中常用的一些注解生效。
要使用contex名称空间,必须在applicationContext.xml文件中引入
![](https://box.kancloud.cn/298927ca77e631023e616bb1780d3774_1230x896.png)
![](https://box.kancloud.cn/a53fd75f892a5c07e12ed45aa8d98911_746x360.png)
![](https://box.kancloud.cn/d51767837f01084d82803f826ccd7626_1044x688.png)
![](https://box.kancloud.cn/3f68fe91f89712eb863ae58402b0ac13_1224x988.png)
![](https://box.kancloud.cn/859e7b5be54735db40cc4db1d6f1a262_1044x688.png)
# 开启使用注解代替配置文件
~~~
<!--
指定扫描bean包下面所有类以及包
注意:扫描包时,会扫描指定包下所有的子孙包
-->
<context:component-scan base-package="studySpring">
</context:component-scan>
~~~
# 在类中使用
在类上这样写
~~~
import org.springframework.stereotype.Component;
@Component("user")
// 相当于 <bean name="user" class="studySpring.User">
public class User {
~~~
Component里面的名字就是bean的名字
来个测试
~~~
// 1. 创建容器对象
ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
// 2. 向容器要user对象
Object u = ac.getBean("user");
// 3.打印user对象
System.out.println(u);
~~~
# 表示在那一层
~~~
@Component("user")
@Service("user") //service层
@Controller("user") //web层
@Repository("user") //dao层
~~~
# 作用域
~~~
@Scope(scopeName = "prototype")
//scopeName取值有singleton|prototype,默认是singleton
~~~
# 注入值
~~~
@Value("tom")
private String name;
//可以忽略value,写成这样@Value("18")
@Value(value = "18")
private Integer age;
~~~
还有种
~~~
@Value("tom")
public void setName(String name) {
this.name = name;
}
~~~
他们区别是上面一个是通过反射name来赋值,下面一个是通过set方法赋值
上面一种赋值是破坏了封装性
**给引用类型注入**
首先对应的类型注入
~~~
@Component("car")
public class Car {
~~~
然后自动装备
~~~
@Autowired // 自动装配
private Car car;
~~~
但是问题来了,匹配多个对象,将无法确定
可以这样,告诉装配那个名称
~~~
@Autowired // 自动装配
@Qualifier("car2")
~~~
也可以这样,指定告诉他要注入那个
~~~
@Resource(name = "car")
private Car car;
~~~
# 初始化方法和销毁方法
~~~
@PostConstruct // 在对象创建后调用,init-method
public void init() {
System.out.println("我是初始化方法!");
}
@PreDestroy // 在销毁之前调用.destory-method
public void destory() {
System.out.println("我是销毁方法!");
}
~~~
- 基础
- 编译和安装
- scanner类(键盘录入)
- Random类(随机数)
- 数组
- 方法
- 类
- ArrayList集合
- char与int
- eclipse
- IDEA
- 变量与常量
- 常用API
- String,StringBuffer,StringBuilder
- 正则,Date,DateFormat,Calendar
- 包装类,System,Math,Arrays,BigInteger,BigDecimal
- 集合,迭代器,增强for,泛型
- List,set,判断集合唯一
- map,Entry,HashMap,Collections
- 异常
- IO
- File
- 递归
- 字节流
- 字符流
- IO流分类
- 转换流
- 缓冲流
- 流的操作规律
- properties
- 序列化流与反序列化流
- 打印流
- commons-IO
- IO流总结
- 多线程
- 线程池
- 线程安全
- 线程同步
- 死锁
- lock接口
- ThreadLoad
- 等待唤醒机制
- 线程状态
- jdbc
- DBUtils
- 连接池DBCP
- c3p0连接池
- 网络编程
- 多线程socket上传图片
- 反射
- xml
- 设计模式
- 装饰器模式
- web service
- tomcat
- Servlet
- response
- request
- session和cookie
- JSP
- EL
- JSTL
- 事务
- 监听器Listener
- 过滤器Filter
- json
- linux安装软件
- 反射详解
- 类加载器和注解
- 动态代理
- jedis
- Hibernate
- 简介
- 创建映射文件
- Hibernate核心配置文件
- 事务和增删改查
- HibernateUtils
- 持久化对象的三种状态
- 检索方式
- query
- Criteria
- SQLQuery
- 持久化类
- 主键生成策略
- 缓存
- 事务管理
- 关系映射
- 注解
- 优化
- struts2
- 搭建
- 配置详解
- Action
- 结果跳转方式
- 访问ServletAPI方式
- 如何获得参数
- OGNL表达式
- valueStack 值栈
- Interceptor拦截器
- spring
- 导包
- IOC和DI
- Bean获取与实例化
- Bean属性注入
- spring注解
- 注解分层
- junit整合
- aop
- 动态代理实现
- cglib代理实现
- aop名词
- spring的aop
- aop-xml详解
- aop-注解详解
- 代理方式选择
- jdbcTemplate
- spring事务管理
- 回滚注意
- 事务传播属性
- MyBatis
- MyBatis简介
- 入门程序
- 与jdbc hibernate不同
- 原始Dao开发
- Mapper动态代理方式
- SqlMapConfig.xml配置文件
- 输入参数pojo包装类
- resultMap
- 动态sql
- 一对一关联
- 一对多
- 整合spring
- 逆向工程
- maven
- maven简介
- 仓库
- maven目录结构
- maven常用命令
- 生命周期
- eclipse中maven插件
- 入门程序
- 整合struct
- 依赖范围
- 添加插件
- idea配置
- jar包冲突
- 分模块开发
- 构建可执行的jar包(包含依赖jar包)
- springMVC
- 处理流程
- java面试
- java版本升级
- java1-8版本变更
- java9新特性
- 锁
- java资料
- idea
- jdk版本切换
- log4j
- 入门实例
- 基本使用方法
- Web中使用Log4j
- spring中使用log4j
- java代码优化