我正在分析java applet的啓動時間。我注意到,每次請求來自jar的資源時,都會讀取一個大小爲5MB的大容量jar文件。 例如圖像日誌配置文件,I18N文件等... 它應該這樣做?是否有可能跳到正確的點?是否有可能只讀取一次文件? 如果我將切換到cache_archiv_ex並添加預加載指令,它會有幫助嗎? jar文件被打開,其中的實施例 :爲每個getResourceAsStream讀取整個jar
java.io.FileInputStream.open(String)
java.io.FileInputStream.<init>(File)
com.sun.deploy.cache.DeployCacheHandler$2.run()
java.security.AccessController.doPrivileged(PrivilegedExceptionAction)
com.sun.deploy.cache.DeployCacheHandler.get(URI, String, Map)
sun.net.www.protocol.http.HttpURLConnection.plainConnect()
sun.net.www.protocol.http.HttpURLConnection.connect()
sun.net.www.protocol.http.HttpURLConnection.getInputStream()
sun.plugin.PluginURLJarFileCallBack.downloadJAR(URLConnection, boolean)
sun.plugin.PluginURLJarFileCallBack.access$000(PluginURLJarFileCallBack, URLConnection, boolean)
sun.plugin.PluginURLJarFileCallBack$2.run()
java.security.AccessController.doPrivileged(PrivilegedExceptionAction)
sun.plugin.PluginURLJarFileCallBack.retrieve(URL)
sun.net.www.protocol.jar.URLJarFile.retrieve(URL, URLJarFile$URLJarFileCloseController)
sun.net.www.protocol.jar.URLJarFile.getJarFile(URL, URLJarFile$URLJarFileCloseController)
sun.net.www.protocol.jar.JarFileFactory.get(URL, boolean)
sun.net.www.protocol.jar.JarURLConnection.connect()
sun.plugin.net.protocol.jar.CachedJarURLConnection.connect()
sun.plugin.net.protocol.jar.CachedJarURLConnection.getInputStream()
java.net.URL.openStream()
java.lang.ClassLoader.getResourceAsStream(String)
sun.plugin2.applet.Applet2ClassLoader.getResourceAsStream(String)
..
.. (real application code stack...)
..
..
java.awt.event.InvocationEvent.dispatch()
java.awt.EventQueue.dispatchEvent(AWTEvent)
java.awt.EventDispatchThread.pumpOneEventForFilters(int)
java.awt.EventDispatchThread.pumpEventsForFilter(int, Conditional, EventFilter)
java.awt.EventDispatchThread.pumpEventsForHierarchy(int, Conditional, Component)
java.awt.EventDispatchThread.pumpEvents(int, Conditional)
java.awt.EventDispatchThread.pumpEvents(Conditional)
java.awt.EventDispatchThread.run()
對'FileInputStream'的引用強烈表明(從緩存而不是套接字讀取)確實正在發生。對我來說有趣的是,一個Java應用程序通常使用內存映射它的jar文件。雖然我可以理解爲什麼applet容器不會這樣做,但是可能有一個JRE中的設置可以啓用它(但我沒看過)。 – kdgregory 2009-12-28 18:36:22
它正在從文件中讀取。我在分析過程時看到它Yourkit 9.0 EAP有一個很好的功能,稱爲探針,顯示讀取的文件和讀取的數據量。 – lifey 2009-12-28 19:33:31
您能解釋一下在applet中不使用內存映射文件的原因嗎? – lifey 2009-12-28 19:35:27