@Configurable
@Aspect
public class FilmCounter {
private Map<Integer, Integer> filmCounts =
new HashMap<Integer, Integer>();
@Pointcut(
"execution(* soundsystem.CompactDisc.play(int)) " +
"&& args(filmNumber)")
public void filmPlayed(int filmNumber) {}
@Before("filmPlayed(filmNumber)")
public void countFilm(int filmNumber){
int currentCount = getPlayCount(filmNumber);
filmCounts.put(filmNumber, currentCount + 1);
System.out.println("filmNumber " + filmNumber + " contains in ? " + filmCounts.containsKey(filmNumber) + " then filmCount = " + filmCounts.get(filmNumber));
}
public int getPlayCount(int filmNumber){
//System.out.println("filmNumber " + filmNumber + " contains in ? " + filmCounts.containsKey(filmNumber) + "");
return filmCounts.containsKey(filmNumber)
? filmCounts.get(filmNumber) : 0;
}
}
配置类
在AspectJ运行LIB所以不需要@EnableAspectJAutoProxy
注释
@Configuration
public class FilmCounterConfig {
@Bean
public CompactDisc filmDisk(){
FilmDisc cd = new FilmDisc();
cd.setTitle("1981's Melody Films");
cd.setArtist("Kishor Kumar");
List<String> films = new ArrayList<String>();
films.add("Sanam Teri Kasam");
films.add("Akhari Rasta");
films.add("Hum Apke Hai Koun");
films.add("Dil Hain Ke Manata Nahi");
films.add("Hum Sath Sath Hain");
cd.setFilms(films);
return cd;
}
@Bean
public FilmCounter filmCounter(){
return new FilmCounter();
}
}
测试类
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes=FilmCounterConfig.class)
public class FilmCounterTest {
@Rule
public final SystemOutRule systemOutRule = new SystemOutRule().enableLog();
@Autowired
private CompactDisc cd;
@Autowired
private FilmCounter counter;
@Test
public void testFilmCounter(){
cd.play(1); System.out.println("counter.getPlayCount(1) = " + counter.getPlayCount(1));
cd.play(2);
cd.play(3);
cd.play(3);
cd.play(3);
cd.play(3);
/*assertEquals(1, counter.getPlayCount(1));
assertEquals(1, counter.getPlayCount(2));
assertEquals(4, counter.getPlayCount(3));
*/
System.out.println("Film 1 = " + counter.getPlayCount(1));
System.out.println("Film 2 = " + counter.getPlayCount(2));
System.out.println("Film 3 = " + counter.getPlayCount(3));
}
}
当运行上面的测试情况下,我得到以下输出:
的图像显示控制台日志输出的第一个方法调用cd.play(2);
看起来不错,但调用System.out.println("Film 1 = " + counter.getPlayCount(1));
后它显示错误的结果(它应该显示“4”,但显示“0”)。
仅供参考,我已重新格式化您的问题,因为您使用的是引用而不是普通或粗体文本。我也照顾让你的内联图片可见。请学习StackOverflow语法。谢谢。 – kriegaex
问题:要理解你想解释的内容有点困难。我特别被这句话困惑:“在AspectJ运行库lib下不需要'@EnableAspectJAutoProxy'注释”是什么意思?你使用LTW(加载时织入)和完整的AspectJ而不是Spring AOP? – kriegaex
对不起。我无法解释,但现在我想说,我不需要使用@EnableAspectJAutoProxy注释来配置FilmCounterConfig类,因为我使用的是STC IDE,并且我在项目的类路径中配置了AspectRuntimeLibrary。我想说。 –