From 14de791d60c2421d8f36084d1f9435ed88901677 Mon Sep 17 00:00:00 2001 From: Alex Menkov Date: Fri, 20 Nov 2020 23:33:11 +0000 Subject: [PATCH] 8255934: JConsole 14 and greater fails to connect to older JVM Reviewed-by: cjplummer, sspitsyn --- .../sun/tools/jconsole/SummaryTab.java | 24 +++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) diff --git a/src/jdk.jconsole/share/classes/sun/tools/jconsole/SummaryTab.java b/src/jdk.jconsole/share/classes/sun/tools/jconsole/SummaryTab.java index ba8b5aba27e..f70f1b1f358 100644 --- a/src/jdk.jconsole/share/classes/sun/tools/jconsole/SummaryTab.java +++ b/src/jdk.jconsole/share/classes/sun/tools/jconsole/SummaryTab.java @@ -32,6 +32,7 @@ import java.lang.reflect.*; import java.text.*; import java.util.*; import java.util.concurrent.*; +import java.util.function.LongSupplier; import javax.swing.*; @@ -257,9 +258,14 @@ class SummaryTab extends Tab { String[] kbStrings1 = formatKByteStrings(sunOSMBean.getCommittedVirtualMemorySize()); + // getTotalPhysicalMemorySize and getFreePhysicalMemorySize are deprecated, + // but we want be able to get the data for old target VMs (see JDK-8255934). + @SuppressWarnings("deprecation") String[] kbStrings2 = - formatKByteStrings(sunOSMBean.getTotalMemorySize(), - sunOSMBean.getFreeMemorySize(), + formatKByteStrings(tryToGet(sunOSMBean::getTotalMemorySize, + sunOSMBean::getTotalPhysicalMemorySize), + tryToGet(sunOSMBean::getFreeMemorySize, + sunOSMBean::getFreePhysicalMemorySize), sunOSMBean.getTotalSwapSpaceSize(), sunOSMBean.getFreeSwapSpaceSize()); @@ -317,6 +323,20 @@ class SummaryTab extends Tab { return result; } + /** + * Tries to get the specified value from the list of suppliers. + * Returns -1 if all suppliers fail. + */ + private long tryToGet(LongSupplier ... getters) { + for (LongSupplier getter : getters) { + try { + return getter.getAsLong(); + } catch (UndeclaredThrowableException e) { + } + } + return -1; + } + private synchronized void append(String str) { buf.append(str); }