具有JRockit兼容性的Hessian



在JRockit VM上运行hessian时,是否有人遇到此异常?

Caused by: java.lang.ArrayIndexOutOfBoundsException: -418
        at com.caucho.hessian.util.IdentityIntMap.put(IdentityIntMap.java:141)
        at com.caucho.hessian.io.Hessian2Output.addRef(Hessian2Output.java:1285)
        at com.caucho.hessian.io.UnsafeSerializer.writeObject(UnsafeSerializer.java:157)
        at com.caucho.hessian.io.Hessian2Output.writeObject(Hessian2Output.java:421)
        at com.caucho.hessian.io.CollectionSerializer.writeObject(CollectionSerializer.java:102)
        at com.caucho.hessian.io.Hessian2Output.writeObject(Hessian2Output.java:421)
        at com.caucho.hessian.io.UnsafeSerializer$ObjectFieldSerializer.serialize(UnsafeSerializer.java:293)
        ... 34 more

我花了一个多星期的时间来解决这个问题,结果发现hessian在HotSpot虚拟机上运行良好,但在使用JRockit虚拟机序列化某些对象时总是失败。我实际上想出了一个简单的修复方法,但它需要修改IdentityIntMap.java代码并更新hessian-jar文件。

以下是我提出的修复方案。我不知道如何通知Hessian代码的维护人员,所以我把它发布在这里。修改文件:

com.caucho.hesesian.util.IdentityIntMap.java从第112行开始:

public final int get(Object key)
{
  int prime = _prime;
  // int hash = System.identityHashCode(key) % prime;
  int hash = System.identityHashCode(key);
  // JRockit VMs can return a negative number which will cause this method to throw an exception
  if (hash < 0)
    hash = -hash;
  hash = hash % prime;
  ...

同时更改从第135行开始的下一个方法中的代码:

public final int put(Object key, int value, boolean isReplace)
{
  int prime = _prime;
  // int hash = System.identityHashCode(key) % prime;
  int hash = System.identityHashCode(key);
  // JRockit VMs can return a negative number which will cause this method to throw an exception
  if (hash < 0)
    hash = -hash;
  hash = hash % prime;
  ...

最新更新