Viktor's Tech Lab

Blog pessoal

JVM: Class Loaders, standard (non-diagnostic) e diagnostic flags, CLI parsing.

Categorias = [ Java, Software ]

A Java Virtual Machine (JVM) é o núcleo do ecossistema Java, fornecendo todas as ferramentas essenciais para a execução de código. Para compreender plenamente seu funcionamento, é crucial entender o ciclo de vida desse interpretador e as suas implicações para o desempenho e otimização de aplicações.

Java Virtual Machine Bootstrapping

Todo o ciclo de vida da JVM inicia-se com um processo fundamental chamado de “JVM Bootstrapping” que é responsável por construir todo o ambiente de execução e prepará-lo. É nesse contexto que: os argumentos passados na linha de comando são interpretados, o código da JVM é alocado na memória, as estruturas de dados internas da JVM são inicializadas, o gerenciamento de memória se inicia, e por fim a principal thread da aplicação passa a operar. Vamos explorar cada subprocesso descrito nesse parágrafo individualmente:

Pipeline de argumentos

Quando se inicia o programa através da linha de comando, a máquina virtual inicia uma cadeia de processos responsáveis por analisar os argumentos fornecidos, os quais podem incluir parâmetros de inicialização,como por exemplo: -Xms e -Xmx para definir o tamanho mínimo e máximo do heap — área da memória responsável pela alocação e criação de objetos no contexto da aplicação — especificações de debug ou configurações até mesmo do próprio ciclo do Garbage Collector.

Antes de prosseguir, é importante mencionar: com o intuito de simplificação, estaremos analisando o segmento do código que lida com o parsing de argumentos avançados da JVM — os que se iniciam com -XX, como explicado no artigo anterior.

Vamos utilizar o código open-source da OpenJDK para mais referências. No arquivo arguments.cpp localizado no diretório src/hotspot/share/runtime.arguments.cpp a função que interpreta parâmetros avançados (-XX) pela CLI é essa: