Posted by agilejava | Posted in JAVA | Posted on 02-02-2011
SLF4J是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志系统。
SLF4J库类似于Apache Commons-Logging,但Apache Commons-Logging采用的是动态绑定机制,使用ClassLoader寻找和载入底层的日志库,而在OSGI中,不同的插件使用自己的ClassLoader,OSGI的这种机制保证了插件互相独立,然而却使得Apache Commons-Logging无法在OSGI的环境下工作了。SLF4J却没有这个问题,它是如何做到的呢?
一个简单的例子:
package chapters.introduction;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class HelloWorld1 {
public static void main(String[] args) {
Logger logger = LoggerFactory.getLogger("chapters.introduction.HelloWorld1");
logger.debug("Hello world.");
}
}
SLF4J与日志系统的绑定过程是在getLogger方法中完成的!下面介绍整个绑定过程。
通过上图大家可以发现整个静态绑定机制的核心是通过查找类路径下面的org/slf4j/impl/StaticLoggerBinder.class,所以类路径下只能有一个这个类。看到这里大家可能会问了,这个类的包名是org.slf4j.impl,找这个类如何与其他的日志系统连接呢?呵呵,这个很简单,其实slf4j的发布包中包含了为多种日志系统写好的绑定代理,每个日志系统都写好了一个独立的StaticLoggerBinder,由这个类调用相关日志系统的对象!
下图是slf4j发布包中的为各个日志系统写好的绑定代理。

为什么没有logback的绑定代理?呵呵,因为logback中已经内置了slf4j的绑定代理。

Posted by agilejava | Posted in JAVA | Posted on 25-05-2010
动态代理类
要了解 Java 动态代理的机制,首先需要了解以下相关的类或接口:
java.lang.reflect.Proxy:这是 Java 动态代理机制的主类,它提供了一组静态方法来为一组接口动态地生成代理类及其对象。
清单 1. Proxy 的静态方法
// 方法 1: 该方法用于获取指定代理对象所关联的调用处理器
static InvocationHandler getInvocationHandler(Object proxy)
// 方法 2:该方法用于获取关联于指定类装载器和一组接口的动态代理类的类对象
static Class getProxyClass(ClassLoader loader, Class[] interfaces)
// 方法 3:该方法用于判断指定类对象是否是一个动态代理类
static boolean isProxyClass(Class cl)
// 方法 4:该方法用于为指定类装载器、一组接口及调用处理器生成动态代理类实例
static Object newProxyInstance(ClassLoader loader, Class[] interfaces,
InvocationHandler h)
java.lang.reflect.InvocationHandler:这是调用处理器接口,它自定义了一个 invoke 方法,用于集中处理在动态代理类对象上的方法调用,通常在该方法中实现对委托类的代理访问。
清单 2. InvocationHandler 的核心方法
该方法负责集中处理动态代理类上的所有方法调用。
第一个参数既是代理类实例。
第二个参数是被调用的方法对象
第三个方法是调用参数。调用处理器根据这三个参数进行预处理或分派到委托类实例上发射执行
Object invoke(Object proxy, Method method, Object[] args)
每次生成动态代理类对象时都需要指定一个实现了该接口的调用处理器对象(参见 Proxy 静态方法 4 的第三个参数)。
java.lang.ClassLoader:这是类装载器类,负责将类的字节码装载到 Java 虚拟机(JVM)中并为其定义类对象,然后该类才能被使用。Proxy 静态方法生成动态代理类同样需要通过类装载器来进行装载才能使用,它与普通类的唯一区别就是其字节码是由 JVM 在运行时动态生成的而非预存在于任何一个 .class 文件中。 每次生成动态代理类对象时都需要指定一个类装载器对象(参见 Proxy 静态方法 4 的第一个参数)
Read the rest of this entry »
Posted by agilejava | Posted in JAVA | Posted on 25-05-2010
在《Spring AOP备忘录–Spring1.X AOP API》中介绍了Spring1.x版本中AOP的使用方式,这种方式用起来还是比较复杂的,备受批评。在Spring2.0中,Spring AOP已经焕然一新了,主要包括两种方式:第一种是@AspectJ注解方式,第二种是基于新的Schema配置方式。
Read the rest of this entry »
Posted by agilejava | Posted in JAVA | Posted on 24-05-2010
在Spring中使用AOP可以有四种方式:Spring1.X中定义的Spring AOP API、@AspectJ方式、Schema方式、集成第三方AOP框架(比如AspectJ)
1 Spring1.X中定义的Spring AOP API,包括:Advice,Advisor,ProxyFactoryBean。
- Advice包括四种类型:环绕通知,前置通知,异常通知,后置通知。
Read the rest of this entry »