1. 程式人生 > >java中的註解大全@controller、@service、@repository等

java中的註解大全@controller、@service、@repository等

參考一篇文章,其中講了@controller、@service、@repository註解,看後很有啟發,自己複製下總結下,新增點東西寫下這篇部落格
controller層使用@controller註解
@Controller 用於標記在一個類上,使用它標記的類就是一個SpringMVC Controller 物件。分發處理器將會掃描使用了該註解的類的方法。通俗來說,被Controller標記的類就是一個控制器,這個類中的方法,就是相應的動作。
@RequestMapping是一個用來處理請求地址對映的註解,可用於類或方法上。用於類上,表示類中的所有響應請求的方法都是以該地址作為父路徑。比如圖一中,跳轉到登入頁面的路徑就是localhost:8080/xxx-war/user/toLogin
service採用@service註解

例:@Service("userService")註解是告訴Spring,當Spring要建立UserServiceImpl的的例項時,bean的名字必須叫做"userService",這樣當Action需要使用UserServiceImpl的的例項時,就可以由Spring建立好的"userService",然後注入給Action。dao層使用@repository註解

@Repository(value="userDao")註解是告訴Spring,讓Spring建立一個名字叫“userDao”的UserDaoImpl例項。

當Service需要使用Spring建立的名字叫“userDao”的UserDaoImpl例項時,就可以使用@Resource(name = "userDao")註解告訴Spring,Spring把建立好的userDao注入給Service即可。

@Autowired   :它可以對類成員變數、方法及建構函式進行標註,完成自動裝配的工作。 通過 @Autowired的使用來消除 set ,get方法。 mapper層使用@Component註解

除此之外四大註解還有很多有用的註解  1、@Override:標示當前的方法定義將覆蓋超類中的方法他告訴我們同時也告訴編譯器我們的這些方法肯定覆蓋了類**裡面的方法,如果註釋掉類**裡面的方法 那麼就會報錯,它需要全部覆蓋某個介面的方法。 2、@Deprecated:它標記就表明這個方法已經過時了,在實際中,我們不想用到一個方法,但是這方法的藉口正在使用,那我們就可以用它註解 3、SuppressWarnings:忽略編譯器警告資訊
下面是元註解

@Target:表示該註解可以用於什麼地方。 
取值(ElementType)包括: 
CONSTRUCTOR:用於描述構造器 
FIELD:用於描述域 
LOCAL_VARIABLE:用於描述區域性變數 
METHOD:用於描述方法 
PACKAGE:用於描述包 
PARAMETER:用於描述引數 
TYPE:用於描述類、介面(包括註解型別) 或enum宣告

@Retention:表示需要在什麼級別儲存該註解資訊。 
取值(RetentionPolicy)包括: 
SOURCE:在原始檔中有效(即原始檔保留) 
CLASS:在class檔案中有效(即class保留) 
RUNTIME:在執行時有效(即執行時保留),因此可以通過反射機制讀取註解的資訊。

@Documented:表示將此註解包含在javadoc中。

@Inherited:表示允許子類繼承父類中的註解。

可以看出 定義註解格式為: 
  public @interface 註解名 {定義體}

1)@Autowired

@Autowired為Spring提供的註解,需要匯入包org.springframework.beans.factory.annotation.Autowired;只按照byType注入。

複製程式碼
public class TestServiceImpl {
    // 下面兩種@Autowired只要使用一種即可
    @Autowired
    private UserDao userDao; // 用於欄位上
    
    @Autowired
    public void setUserDao(UserDao userDao) { // 用於屬性的方法上
        this.userDao = userDao;
    }
}
複製程式碼

@Autowired註解是按照型別(byType)裝配依賴物件,預設情況下它要求依賴物件必須存在,如果允許null值,可以設定它的required屬性為false。如果我們想使用按照名稱(byName)來裝配,可以結合@Qualifier註解一起使用。如下:

public class TestServiceImpl {
    @Autowired
    @Qualifier("userDao")
    private UserDao userDao; 
}

(2)@Resource

@Resource預設按照ByName自動注入,由J2EE提供,需要匯入包javax.annotation.Resource。@Resource有兩個重要的屬性:name和type,而Spring將@Resource註解的name屬性解析為bean的名字,而type屬性則解析為bean的型別。所以,如果使用name屬性,則使用byName的自動注入策略,而使用type屬性時則使用byType自動注入策略。如果既不制定name也不制定type屬性,這時將通過反射機制使用byName自動注入策略。

複製程式碼
public class TestServiceImpl {
    // 下面兩種@Resource只要使用一種即可
    @Resource(name="userDao")
    private UserDao userDao; // 用於欄位上
    
    @Resource(name="userDao")
    public void setUserDao(UserDao userDao) { // 用於屬性的setter方法上
        this.userDao = userDao;
    }
}
複製程式碼

注:最好是將@Resource放在setter方法上,因為這樣更符合面向物件的思想,通過set、get去操作屬性,而不是直接去操作屬性。

@Resource裝配順序:

①如果同時指定了name和type,則從Spring上下文中找到唯一匹配的bean進行裝配,找不到則丟擲異常。

②如果指定了name,則從上下文中查詢名稱(id)匹配的bean進行裝配,找不到則丟擲異常。

③如果指定了type,則從上下文中找到類似匹配的唯一bean進行裝配,找不到或是找到多個,都會丟擲異常。

④如果既沒有指定name,又沒有指定type,則自動按照byName方式進行裝配;如果沒有匹配,則回退為一個原始型別進行匹配,如果匹配則自動裝配。

@Resource的作用相當於@Autowired,只不過@Autowired按照byType自動注入。

差不多所有的註解都在這裡了,想要一起學習java的童鞋關注公眾號《一碗肉絲麵》一起學習啊


參考文章:http://blog.csdn.net/wojiaowo11111/article/details/51605213