DWR 使用反射机制在转换过程中找到它应该使用的类型。有时候类型的信息无法获得,在这种情况下你要

在此处用方法签名给予暗示。

signatures 段使 DWR 能确定集合中存放的数据类型。例如下面的定义中我们无法知道 list 中存放的是什么

类型。

public class Check {
public void setLotteryResults(List nos)
{
...
}
}

signatures 段允许我们暗示 DWR 应该用什么类型去处理。格式对以了解 JDK5 的泛型的人来说很容易理解。

<signatures>
<![CDATA[
import java.util.List;
import com.example.Check;
Check.setLotteryResults(List<Integer> nos);
]]>
</signatures>

DWR 中又一个解析器专门来做这件事,所以即便你的环境时 JDK1.3 DWR 也能正常工作。

解析规则基本上会和你预想规则的一样(有两个例外),所以 java.lang 下面的类型会被默认 import。

第一个是 DWR1.0 中解析器的 bug,某些环境下不能返回正确类型。所以你也不用管它了。

第二个是这个解析器时"阳光(sunny day)"解析器。就是说它非常宽松,不想编译器那样严格的保证你一定正确。

所以有时它也会允许你丢失 import:

<signatures>
<![CDATA[
import java.util.List;
Check.setLotteryResults(List<Integer>);
]]>
</signatures>

将来的 DWR 版本会使用一个更正式的解析器,这个编译器会基于官方 Java 定义,所以你最好不要使用太

多这个不严格的东西。

signatures 段只是用来确定泛型参数中的类型参数。DWR 会自己使用反射机制或者运行时类型确定类型,

或者假设它是一个 String 类型。所以:

不需要 signatures - 没有泛型参数:

public void method(String p);
public void method(String[] p);

需要 signatures - DWR 不能通过反射确定:

public void method(List<Date> p);
public void method(Map<String, WibbleBean> p);

不需要 signatures - DWR 能正确的猜出:

public void method(List<String> p);
public void method(Map<String, String> p);

不需要 signatures - DWR 可以通过运行时类型确定:

​public List<Date> method(String p);​

没有必要让 Javascript 中的所有对象的 key 都是 String 类型 - 你可以使用其他类型作为 key。但是他们在使用之前会被转换成 String 类型。DWR1.x 用 Javascript 的特性把 key 转换成 String。DWR2.0 可能会用toString()方法,在服务段进行这一转换。