詳解spring切面使用傳遞給被通知方法的參數(shù)
本文介紹了詳解spring切面使用傳遞給被通知方法的參數(shù),分享給大家,具體如下:
場景:
BlankDisc代表CD實(shí)體,可以通過playTrack()方法直接播放某一個(gè)磁道中的歌曲。
需求是記錄每個(gè)磁道被播放的次數(shù)。
一種方法就是修改playTrack()方法,直接在每次調(diào)用的時(shí)候記錄這個(gè)數(shù)量。但是,記錄磁道的播放次數(shù)與播放本身是不同的關(guān)注點(diǎn),因此不應(yīng)該屬于playTrack()方法。這應(yīng)該是切面要完成的任務(wù)。
CompactDisc接口
public interface CompactDisc {
//播放某一個(gè)磁道中的歌曲
void playTrack(String track);
}
實(shí)現(xiàn)類BlankDisc
public class BlankDisc implements CompactDisc {
private String title;
private String artist;
private List<String> tracks;
public void setTitle(String title) {
this.title = title;
}
public void setArtist(String artist) {
this.artist = artist;
}
public void setTracks(List<String> tracks) {
this.tracks = tracks;
}
@Override
public void playTrack(String track) {
System.out.println("-Track: " + track);
}
}
切面類TraceCount
/**
* 切面類的任務(wù):記錄每個(gè)磁道被播放的次數(shù)
* Created by Administrator on 2017/12/1.
*/
@Component
@Aspect
public class TrackCounter {
private Map<String, Integer> trackCounts = new HashMap<>();
@Pointcut("execution(* chapter04.aop_args.BlankDisc.playTrack(String)) && args(track)")
public void trackPlayed(String track) {
}
//在播放前,為該磁道計(jì)數(shù)
@Before("trackPlayed(track)")
public void countTrack(String track) {
int currentCount = getPlayCount(track);
trackCounts.put(track, currentCount + 1);
}
public int getPlayCount(String track) {
return trackCounts.containsKey(track) ? trackCounts.get(track) : 0;
}
}
applicationContext.xml配置文件
<context:component-scan base-package="aop_test,chapter04"/>
<bean id="compactDisc"
class="chapter04.aop_args.BlankDisc">
<property name="title" value="Sgt. Pepper's Lonely Hearts Club Band" />
<property name="artist" value="The Beatles" />
<property name="tracks">
<list>
<value>Sgt. Pepper's Lonely Hearts Club Band</value>
<value>With a Little Help from My Friends</value>
<value>Lucy in the Sky with Diamonds</value>
<value>Getting Better</value>
<value>Fixing a Hole</value>
<value>She's Leaving Home</value>
<value>Being for the Benefit of Mr. Kite!</value>
<value>Within You Without You</value>
<value>When I'm Sixty-Four</value>
<value>Lovely Rita</value>
<value>Good Morning Good Morning</value>
<value>Sgt. Pepper's Lonely Hearts Club Band (Reprise)</value>
<value>A Day in the Life</value>
</list>
</property>
</bean>
<!-- 開啟aop注解 -->
<aop:aspectj-autoproxy/>
測試
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class test_aop_args {
@Autowired
CompactDisc cd;
@Autowired
TrackCounter trackCounter;
@Test
public void test(){
cd.playTrack("Sgt. Pepper's Lonely Hearts Club Band");
cd.playTrack("With a Little Help from My Friends");
cd.playTrack("Lucy in the Sky with Diamonds");
cd.playTrack("Sgt. Pepper's Lonely Hearts Club Band");
cd.playTrack("With a Little Help from My Friends");
cd.playTrack("Sgt. Pepper's Lonely Hearts Club Band");
System.out.println(trackCounter.getPlayCount("Sgt. Pepper's Lonely Hearts Club Band"));
System.out.println(trackCounter.getPlayCount("With a Little Help from My Friends"));
System.out.println(trackCounter.getPlayCount("Lucy in the Sky with Diamonds"));
System.out.println(trackCounter.getPlayCount("Getting Better"));
}
}
測試結(jié)果 3,2,1,0
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Spring注解配置AOP導(dǎo)致通知執(zhí)行順序紊亂解決方案
- Spring Cloud Admin健康檢查 郵件、釘釘群通知的實(shí)現(xiàn)
- 如何使用Spring AOP的通知類型及創(chuàng)建通知
- Spring AOP的五種通知方式代碼實(shí)例
- spring boot 使用Aop通知打印控制器請(qǐng)求報(bào)文和返回報(bào)文問題
- 詳解Spring Boot Admin監(jiān)控服務(wù)上下線郵件通知
- SpringBoot+LayIM+t-io 實(shí)現(xiàn)好友申請(qǐng)通知流程
- 淺談spring aop的五種通知類型
- 通過實(shí)例解析spring環(huán)繞通知原理及用法
相關(guān)文章
bug解決Failed_to_execute_goal_org.springframework
這篇文章主要為大家介紹了bug解決Failed_to_execute_goal_org.springframework,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
Java后綴數(shù)組之求sa數(shù)組的實(shí)例代碼
后綴數(shù)組就是一個(gè)字符串所有后綴大小排序后的一個(gè)集合,然后我們根據(jù)后綴數(shù)組的一些性質(zhì)就可以實(shí)現(xiàn)各種需求。這篇文章主要介紹了Java后綴數(shù)組-求sa數(shù)組,需要的朋友可以參考下2018-04-04
解決mybatis plus報(bào)錯(cuò)com.microsoft.sqlserver.jdbc.SQLServerE
這篇文章主要介紹了解決mybatis plus報(bào)錯(cuò)com.microsoft.sqlserver.jdbc.SQLServerException:必須執(zhí)行該語句才能獲得結(jié)果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05
SpringBoot Test 多線程報(bào)錯(cuò)的根本原因(dataSource already
Java中String的split切割字符串方法實(shí)例及擴(kuò)展

