]> source.dussan.org Git - javassist.git/commitdiff
fixed JASSIST-150 (fixed a bug on WeakHashMap)
authorchiba <chiba@30ef5769-5b8d-40dd-aea6-55b5d6557bb3>
Sat, 11 Feb 2012 14:54:43 +0000 (14:54 +0000)
committerchiba <chiba@30ef5769-5b8d-40dd-aea6-55b5d6557bb3>
Sat, 11 Feb 2012 14:54:43 +0000 (14:54 +0000)
git-svn-id: http://anonsvn.jboss.org/repos/javassist/trunk@612 30ef5769-5b8d-40dd-aea6-55b5d6557bb3

src/main/javassist/compiler/MemberResolver.java
src/test/Jassist150.java
src/test/javassist/JvstTest4.java

index f35b0ef606f33a23fdce85c6b609d22aaa3dab6c..4ab304fe6afdf8f8cf4c881be3748393fd39e894 100644 (file)
@@ -17,6 +17,7 @@
 package javassist.compiler;
 
 import java.util.Hashtable;
+import java.lang.ref.WeakReference;
 import java.util.WeakHashMap;
 import java.util.List;
 import java.util.Iterator;
@@ -416,14 +417,20 @@ public class MemberResolver implements TokenId {
     private static WeakHashMap invalidNamesMap = new WeakHashMap();
     private Hashtable invalidNames = null;
 
+    // for unit tests
+    public static int getInvalidMapSize() { return invalidNamesMap.size(); }
+
     private Hashtable getInvalidNames() {
         Hashtable ht = invalidNames;
         if (ht == null) {
             synchronized (MemberResolver.class) {
-                ht = (Hashtable)invalidNamesMap.get(classPool);
+                WeakReference ref = (WeakReference)invalidNamesMap.get(classPool);
+                if (ref != null)
+                    ht = (Hashtable)ref.get();
+
                 if (ht == null) {
                     ht = new Hashtable();
-                    invalidNamesMap.put(classPool, ht);
+                    invalidNamesMap.put(classPool, new WeakReference(ht));
                 }
             }
 
index 741add0ca2c92229d4ea1a142160d8312e63d79c..1435e27449ff35405de1b3038bdbac0639935a26 100644 (file)
@@ -5,64 +5,88 @@ import javassist.CtMethod;
 import javassist.NotFoundException;
 
 public class Jassist150 {
-
-    public static final String BASE_PATH="./";
-    public static final String JAVASSIST_JAR=BASE_PATH+"javassist.jar";
-    public static final String CLASSES_FOLDER=BASE_PATH+"build/classes";
-    public static final String TEST_CLASSES_FOLDER=BASE_PATH+"build/test-classes";
+    public static final String BASE_PATH = "./";
+    public static final String JAVASSIST_JAR = BASE_PATH + "javassist.jar";
+    public static final String CLASSES_FOLDER = BASE_PATH + "build/classes";
+    public static final String TEST_CLASSES_FOLDER = BASE_PATH
+            + "build/test-classes";
 
     public static class Inner1 {
-      public static int get() {
-        return 0;
-      }
+        public static int get() {
+            return 0;
+        }
     }
 
-    public static void implTestClassTailCache() throws NotFoundException, CannotCompileException {
-      ClassPool pool = new ClassPool(true);
-      for(int paths=0; paths<50; paths++) {
-        pool.appendClassPath(JAVASSIST_JAR);
-        pool.appendClassPath(CLASSES_FOLDER);
-        pool.appendClassPath(TEST_CLASSES_FOLDER);
-      }
-      CtClass cc = pool.get("Jassist150$Inner1");
-      CtMethod ccGet = cc.getDeclaredMethod("get");
-      String code1 = "{ int n1 = Integer.valueOf(1); " +
-          "  int n2 = Integer.valueOf(2); " +
-          "  int n3 = Integer.valueOf(3); " +
-          "  int n4 = Integer.valueOf(4); " +
-          "  int n5 = Integer.valueOf(5); " +
-          "  return n1+n2+n3+n4+n5; }";
-      String code2 = "{ int n1 = java.lang.Integer.valueOf(1); " +
-          "  int n2 = java.lang.Integer.valueOf(2); " +
-          "  int n3 = java.lang.Integer.valueOf(3); " +
-          "  int n4 = java.lang.Integer.valueOf(4); " +
-          "  int n5 = java.lang.Integer.valueOf(5); " +
-          "  return n1+n2+n3+n4+n5; }";
-      String code3 = "{ int n1 = java.lang.Integer#valueOf(1); " +
-          "  int n2 = java.lang.Integer#valueOf(2); " +
-          "  int n3 = java.lang.Integer#valueOf(3); " +
-          "  int n4 = java.lang.Integer#valueOf(4); " +
-          "  int n5 = java.lang.Integer#valueOf(5); " +
-          "  return n1+n2+n3+n4+n5; }";
-      loop(cc, ccGet, code1);
+    public static void implTestClassTailCache() throws NotFoundException,
+            CannotCompileException {
+        ClassPool pool = new ClassPool(true);
+        for (int paths = 0; paths < 50; paths++) {
+            pool.appendClassPath(JAVASSIST_JAR);
+            pool.appendClassPath(CLASSES_FOLDER);
+            pool.appendClassPath(TEST_CLASSES_FOLDER);
+        }
+        CtClass cc = pool.get("Jassist150$Inner1");
+        CtMethod ccGet = cc.getDeclaredMethod("get");
+        String code1 = "{ int n1 = Integer.valueOf(1); "
+                + "  int n2 = Integer.valueOf(2); "
+                + "  int n3 = Integer.valueOf(3); "
+                + "  int n4 = Integer.valueOf(4); "
+                + "  int n5 = Integer.valueOf(5); "
+                + "  return n1+n2+n3+n4+n5; }";
+        String code2 = "{ int n1 = java.lang.Integer.valueOf(1); "
+                + "  int n2 = java.lang.Integer.valueOf(2); "
+                + "  int n3 = java.lang.Integer.valueOf(3); "
+                + "  int n4 = java.lang.Integer.valueOf(4); "
+                + "  int n5 = java.lang.Integer.valueOf(5); "
+                + "  return n1+n2+n3+n4+n5; }";
+        String code3 = "{ int n1 = java.lang.Integer#valueOf(1); "
+                + "  int n2 = java.lang.Integer#valueOf(2); "
+                + "  int n3 = java.lang.Integer#valueOf(3); "
+                + "  int n4 = java.lang.Integer#valueOf(4); "
+                + "  int n5 = java.lang.Integer#valueOf(5); "
+                + "  return n1+n2+n3+n4+n5; }";
+        loop(cc, ccGet, code1);
     }
 
-    public static void loop(CtClass cc, CtMethod ccGet, String code) throws CannotCompileException {
+    public static void loop(CtClass cc, CtMethod ccGet, String code)
+            throws CannotCompileException {
         long startTime = System.currentTimeMillis();
-        for(int replace=0; replace<1000; replace++) {
+        for (int replace = 0; replace < 1000; replace++) {
             ccGet.setBody(code);
         }
         long endTime = System.currentTimeMillis();
-        System.out.println("Test: Time (ms) "+(endTime-startTime));
+        System.out.println("Test: Time (ms) " + (endTime - startTime));
+    }
+
+    public static void implTestClassTailCache2() throws NotFoundException,
+            CannotCompileException {
+        ClassPool pool = new ClassPool(true);
+        for (int paths = 0; paths < 50; paths++) {
+            pool.appendClassPath(JAVASSIST_JAR);
+            pool.appendClassPath(CLASSES_FOLDER);
+            pool.appendClassPath(TEST_CLASSES_FOLDER);
+        }
+        CtClass cc = pool.get("Jassist150$Inner1");
+        CtMethod ccGet = cc.getDeclaredMethod("get");
+        String code3 = "{ int n1 = java.lang.Integer#valueOf(1); "
+                + "  int n2 = java.lang.Integer#valueOf(2); "
+                + "  int n3 = java.lang.Integer#valueOf(3); "
+                + "  int n4 = java.lang.Integer#valueOf(4); "
+                + "  int n5 = java.lang.Integer#valueOf(5); "
+                + "  return n1+n2+n3+n4+n5; }";
+        ccGet.setBody(code3);
     }
 
     public static void main(String[] args) {
-    for (int loop = 0; loop < 5; loop++) {
-        try {
+        for (int loop = 0; loop < 5; loop++) {
+            try {
                 implTestClassTailCache();
+                for (int i = 0; i < 100; i++)
+                    implTestClassTailCache2();
             } catch (Exception e) {
                 e.printStackTrace();
             }
+        }
+        System.out.println("size: " + javassist.compiler.MemberResolver.getInvalidMapSize());
     }
-  }
-}
\ No newline at end of file
+}
index 3a2dca5538b0c466dc27e1d3498f6993f2638173..54e2458412833802a128323824b140d59c6c5840 100644 (file)
@@ -657,4 +657,31 @@ public class JvstTest4 extends JvstTestRoot {
         assertTrue(t2 < t1 * 2);
         assertTrue(t3 < t1 * 2);
     }
+
+    public void testJIRA150b() throws Exception {
+        int N = 100;
+        for (int k = 0; k < N; k++) {
+            ClassPool pool = new ClassPool(true);
+            for(int paths=0; paths<50; paths++) {
+                pool.appendClassPath(JAVASSIST_JAR);
+                pool.appendClassPath(CLASSES_FOLDER);
+                pool.appendClassPath(TEST_CLASSES_FOLDER);
+            }
+            CtClass cc = pool.get("Jassist150$Inner1");
+            CtMethod ccGet = cc.getDeclaredMethod("get");
+            for(int replace=0; replace < 5; replace++) {
+                ccGet.setBody(
+                    "{ int n1 = java.lang.Integer#valueOf(1); " +
+                    "  int n2 = java.lang.Integer#valueOf(2); " +
+                    "  int n3 = java.lang.Integer#valueOf(3); " +
+                    "  int n4 = java.lang.Integer#valueOf(4); " +
+                    "  int n5 = java.lang.Integer#valueOf(5); " +
+                    "  return n1+n2+n3+n4+n5; }");
+            }
+        }
+        System.gc();
+        int size = javassist.compiler.MemberResolver.getInvalidMapSize();
+        System.out.println("JIRA150b " + size);
+        assertTrue(size < N - 10);
+    }
 }