[TOC]
# 導入新的約束
在spring中使用注解,我們必須在applicationContext.xml文件中添加一個標簽
`<context:annotation-config/>`作用是讓spring中常用的一些注解生效。
要使用contex名稱空間,必須在applicationContext.xml文件中引入





# 開啟使用注解代替配置文件
~~~
<!--
指定掃描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代碼優化