Descobri que o HotSpot lista todos os argumentos da VM no bean de gerenciamento, exceto -client e -server. Portanto, se você inferir o argumento -client / -server a partir do nome da VM e adicioná-lo à lista do bean de gerenciamento de tempo de execução, obterá a lista completa de argumentos.
Aqui está o SSCCE:
import java.util.*;
import java.lang.management.ManagementFactory;
class main {
public static void main(final String[] args) {
System.out.println(fullVMArguments());
}
static String fullVMArguments() {
String name = javaVmName();
return (contains(name, "Server") ? "-server "
: contains(name, "Client") ? "-client " : "")
+ joinWithSpace(vmArguments());
}
static List<String> vmArguments() {
return ManagementFactory.getRuntimeMXBean().getInputArguments();
}
static boolean contains(String s, String b) {
return s != null && s.indexOf(b) >= 0;
}
static String javaVmName() {
return System.getProperty("java.vm.name");
}
static String joinWithSpace(Collection<String> c) {
return join(" ", c);
}
public static String join(String glue, Iterable<String> strings) {
if (strings == null) return "";
StringBuilder buf = new StringBuilder();
Iterator<String> i = strings.iterator();
if (i.hasNext()) {
buf.append(i.next());
while (i.hasNext())
buf.append(glue).append(i.next());
}
return buf.toString();
}
}
Pode ser reduzido se você quiser os argumentos em a List<String>
.
Nota final: também podemos estender isso para lidar com o caso raro de ter espaços nos argumentos da linha de comando.