1.传统编程模式的弊端
通过以下案例你将会发现,虽然在调用addUser()方法时实现了日志的输出,但这个程序有一个问题,
就是不得不在addUser()方法的主业务代码前面添加"log.info(“开始添加用户。。。”)语句,
以及在主业务代码后面添加"log.info("完成添加用户。。。)"语句。
这些语句以硬编码的方式混入主业务代码中,难以分割,可移植性差。
解决问题的思路是将这些日志之类的功能独立出来,作为独立的一个或多个类,在需要时调用,
而且最好不是显示调用,因为如果时显示调用,仍然要在目标方法前面或后面嵌入代码,改进效果有限,最好能自动调用。
这种设想就是一种面向切面编程(AOP)的思想。
应用实例:创建一个分层架构项目,在添加用户的同时输出日志。
项目目录结构图
IUserDao.java
package com.xiaochen.dao;
public interface IUserDao {
public void addUser();
}
UserDaoImpl.java
package com.xiaochen.dao;
import org.springframework.stereotype.Component;
//使用注解方式定义一个Bean,其id为userDao
@Component("userDao")
public class UserDaoImpl implements IUserDao{
@Override
public void addUser() {
System.out.println("新增一个用户到数据库中");
}
}
UserService.java
package com.xiaochen.service;
import javax.annotation.Resource;
import org.springframework.stereotype.Component;
import com.sun.istack.internal.logging.Logger;
import com.xiaochen.dao.IUserDao;
//使用注解方式定义Bean,其id为userService
@Component("userService")
public class UserService {
//使用注解注入在UserDaoImpl定义好的Bean
@Resource(name="userDao")
private IUserDao userDao;