6826801: JarFileFactory should not use HashMap<URL>

Replace URL with a String representation.

Reviewed-by: michaelm, jccollet
This commit is contained in:
Chris Hegarty 2009-08-07 10:51:25 +01:00
parent 75379fe244
commit aca1227406
2 changed files with 28 additions and 24 deletions

View File

@ -25,12 +25,14 @@
package sun.net.www.protocol.jar; package sun.net.www.protocol.jar;
import java.io.*; import java.io.IOException;
import java.net.*; import java.io.FileNotFoundException;
import java.util.*; import java.net.URL;
import java.util.jar.*; import java.net.URLConnection;
import java.util.zip.ZipFile; import java.util.HashMap;
import java.util.jar.JarFile;
import java.security.Permission; import java.security.Permission;
import sun.net.util.URLUtil;
/* A factory for cached JAR file. This class is used to both retrieve /* A factory for cached JAR file. This class is used to both retrieve
* and cache Jar files. * and cache Jar files.
@ -41,13 +43,13 @@ import java.security.Permission;
class JarFileFactory implements URLJarFile.URLJarFileCloseController { class JarFileFactory implements URLJarFile.URLJarFileCloseController {
/* the url to file cache */ /* the url to file cache */
private static HashMap fileCache = new HashMap(); private static HashMap<String, JarFile> fileCache = new HashMap<String, JarFile>();
/* the file to url cache */ /* the file to url cache */
private static HashMap urlCache = new HashMap(); private static HashMap<JarFile, URL> urlCache = new HashMap<JarFile, URL>();
URLConnection getConnection(JarFile jarFile) throws IOException { URLConnection getConnection(JarFile jarFile) throws IOException {
URL u = (URL)urlCache.get(jarFile); URL u = urlCache.get(jarFile);
if (u != null) if (u != null)
return u.openConnection(); return u.openConnection();
@ -72,7 +74,7 @@ class JarFileFactory implements URLJarFile.URLJarFileCloseController {
synchronized (this) { synchronized (this) {
result = getCachedJarFile(url); result = getCachedJarFile(url);
if (result == null) { if (result == null) {
fileCache.put(url, local_result); fileCache.put(URLUtil.urlNoFragString(url), local_result);
urlCache.put(local_result, url); urlCache.put(local_result, url);
result = local_result; result = local_result;
} else { } else {
@ -97,15 +99,15 @@ class JarFileFactory implements URLJarFile.URLJarFileCloseController {
* remove the JarFile from the cache * remove the JarFile from the cache
*/ */
public void close(JarFile jarFile) { public void close(JarFile jarFile) {
URL urlRemoved = (URL) urlCache.remove(jarFile); URL urlRemoved = urlCache.remove(jarFile);
if( urlRemoved != null) { if( urlRemoved != null) {
fileCache.remove(urlRemoved); fileCache.remove(URLUtil.urlNoFragString(urlRemoved));
} }
} }
private JarFile getCachedJarFile(URL url) { private JarFile getCachedJarFile(URL url) {
JarFile result = (JarFile)fileCache.get(url); JarFile result = fileCache.get(URLUtil.urlNoFragString(url));
/* if the JAR file is cached, the permission will always be there */ /* if the JAR file is cached, the permission will always be there */
if (result != null) { if (result != null) {

View File

@ -25,12 +25,14 @@
package sun.net.www.protocol.jar; package sun.net.www.protocol.jar;
import java.io.*; import java.io.IOException;
import java.net.*; import java.io.FileNotFoundException;
import java.util.*; import java.net.URL;
import java.util.jar.*; import java.net.URLConnection;
import java.util.zip.ZipFile; import java.util.HashMap;
import java.util.jar.JarFile;
import java.security.Permission; import java.security.Permission;
import sun.net.util.URLUtil;
/* A factory for cached JAR file. This class is used to both retrieve /* A factory for cached JAR file. This class is used to both retrieve
* and cache Jar files. * and cache Jar files.
@ -41,13 +43,13 @@ import java.security.Permission;
class JarFileFactory implements URLJarFile.URLJarFileCloseController { class JarFileFactory implements URLJarFile.URLJarFileCloseController {
/* the url to file cache */ /* the url to file cache */
private static HashMap fileCache = new HashMap(); private static HashMap<String, JarFile> fileCache = new HashMap<String, JarFile>();
/* the file to url cache */ /* the file to url cache */
private static HashMap urlCache = new HashMap(); private static HashMap<JarFile, URL> urlCache = new HashMap<JarFile, URL>();
URLConnection getConnection(JarFile jarFile) throws IOException { URLConnection getConnection(JarFile jarFile) throws IOException {
URL u = (URL)urlCache.get(jarFile); URL u = urlCache.get(jarFile);
if (u != null) if (u != null)
return u.openConnection(); return u.openConnection();
@ -82,7 +84,7 @@ class JarFileFactory implements URLJarFile.URLJarFileCloseController {
synchronized (this) { synchronized (this) {
result = getCachedJarFile(url); result = getCachedJarFile(url);
if (result == null) { if (result == null) {
fileCache.put(url, local_result); fileCache.put(URLUtil.urlNoFragString(url), local_result);
urlCache.put(local_result, url); urlCache.put(local_result, url);
result = local_result; result = local_result;
} else { } else {
@ -107,14 +109,14 @@ class JarFileFactory implements URLJarFile.URLJarFileCloseController {
* remove the JarFile from the cache * remove the JarFile from the cache
*/ */
public void close(JarFile jarFile) { public void close(JarFile jarFile) {
URL urlRemoved = (URL) urlCache.remove(jarFile); URL urlRemoved = urlCache.remove(jarFile);
if( urlRemoved != null) { if( urlRemoved != null) {
fileCache.remove(urlRemoved); fileCache.remove(URLUtil.urlNoFragString(urlRemoved));
} }
} }
private JarFile getCachedJarFile(URL url) { private JarFile getCachedJarFile(URL url) {
JarFile result = (JarFile)fileCache.get(url); JarFile result = fileCache.get(URLUtil.urlNoFragString(url));
/* if the JAR file is cached, the permission will always be there */ /* if the JAR file is cached, the permission will always be there */
if (result != null) { if (result != null) {