快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

学习笔记-标签使用(J2SE5.0)中的元数据

方式和注释
要把你的JAVA代码和AOP结合起来,可以使用一些标签,就像新的JDK5.0版本中的元数据以及XDoclet
。对于你的JAVA方式,就有点像使用synchronized相同。当你把你的方式标注为synchronized,就表明
你高数JVM你的这个方式在执行的使用是需要同步的。注释标签答应你定义新的要害词用来处理你自己
的特别行为。AOP就使你有了把这些织入到你的应用中,以使应用可以执行的能力。

让我们看看我们使用自己定义的标签@Oneway来使一个方式在后台的另外一个线程执行。
import org.jboss.aspects.Oneway;

public class Foo
{
@Oneway public static void someMethod() {...}

public static void main(String[] args)
{
someMethod(); // executes in background
}
}

当我们的MAIN方式调用 Msomeethod方式的时候,起始它的执行是和MAIN方式平行的另外一个同步方式中
执行。
要执行这个类,我们必须首先定义自己的标签到JAVA语法中。
package org.jboss.aspects;

import java.lang.annotation.ElementType;
import java.lang.annotation.Target;

@Target({ElementType.METHOD})
public @interface Oneway {}
这就够了。@Target可以限制你的标签的应用范围。在这里你的Oneway就只能被用于方式。上面这些
是纯粹的J2SE5.0里面应用。

下面的是我们的方面,用来执行@Oneway的行为。

package org.jboss.aspects;

public OnewayAspect
{
private static class Task implements Runnable
{
private MethodInvocation invocation;

public Task(MethodInvocation invocation)
{
this.invocation = invocation;
}
public void run()
{
try { invocation.invokeNext(); }
catch (Throwable ignore) { }
}
}


public Object oneway(MethodInvocation invocation) throws Throwable
{
MethodInvocation copy = invocation.copy();
Thread t = new Thread(new Task(copy));
t.setDaemon(false);
t.start();
return null;
}
}

我们的方面就是这么简朴。
最后就是我们要定义切入点

<aop>
<aspect class="org.jboss.aspects.OnewayAspect"/>

<bind pointcut="execution(void *->@org.jboss.Oneway(..))">
<advice name="oneway"
aspect="org.jboss.aspects.OnewayAspect"/>
</bind>
</aop>

这个定义表明了只有是void的被标注为@Oneway的方式才被我们OnewayAspect执行。这样就可以把你
其它应用加上去,这就是简朴,清楚,方便的JAVA预言。

字段和注释
通过AOP我们也可以定义我们自己的字段意思,例如我们可以定义一个ThreadLocal的字段,假如
使用以前的方式,我们就必须使用很多GET()和SET()才能实现。而现在我们可以直接定义一个
@ThreadLocal的类型。

要使用这个新的类型可以像这样:
import org.jboss.aspects.Threadbased;

public class Foo
{
@Threadbased private int counter;
}

首先我们要定义这个类型
package org.jboss.aspects;

import java.lang.annotation.ElementType;
import java.lang.annotation.Target;

@Target({ElementType.FIELD})
public @interface Threadbased {}

这样就可以了,现在所有被标注为@Threadbased的字段都将被应用到这里来,但这里限制了此类型
只能用户字段。

下面就是实现我们的方面来做详细的工作。

package org.jboss.aspects;

import org.jboss.aop.joinpoint.*;
import java.lang.reflect.Field;

public class ThreadbasedAspect
{
private ThreadLocal threadbased = new ThreadLocal();

public Object access(FieldReadInvocation invocation)
throws Throwable
{
// just in case we have a primitive,
// we can\\\'t return null
if (threadbased.get() == null)
return invocation.invokeNext();
return threadbased.get();
}

public Object access(FieldWriteInvocation invocation)
throws Throwable
{
threadbased.set(invocation.getValue());
return null;
}
}
最后定义切入点
<aop>
<aspect class="org.jboss.aspects.ThreadbasedAspect"
scope="PER_JOINPOINT"/>
<bind pointcut="field(* *->@org.jboss.aspects.Threadbased)">
<advice name="access"
aspect="org.jboss.aspects.ThreadbasedAspect"/>
</bind>
</aop>

我们的希望是为每个字段都进行实例化的时候使之成为一个Threadlocal的静态变量,所以在
定义切入点的时候我们使用了PER_JOINPOINT,让JBOSS AOP知道为我们每个字段都要实例化
一个新的ThreadLocal,否则JBOSS AOP只会我们实例化一个ThreadbasedAspect,假如这样就
会让所有的字段共享一个Threadlocal,这明显不是我们所期望的。

和上面相同,在这里我们看到了干净的,轻易集成的方式实现了定义新的JAVA类型。






返回类别: 教程
上一教程: 使用Hibernate 和 Spring 实现一个事务持久层
下一教程: [Eclipse笔记]一个最简朴的SWT程序

您可以阅读与"学习笔记-标签使用(J2SE5.0)中的元数据"相关的教程:
· Struts学习笔记: Html标签库学习(Html基本标签)
· JSP学习笔记__JSP标签库
· Struts学习笔记: Html标签库学习(Form标签)
· java学习笔记--Hiding implementation
· java 学习笔记
    微笑服务 优质保证 索取样品