DEV Community

Victor Hugo
Victor Hugo

Posted on

Java Virtual Machine: ciclo de vida e Class Loaders

A Java Virtual Machine (JVM) é o núcleo do ecossistema Java, fornecendo todas as ferramentas essenciais para a execução de código Java. 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.

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:

Os argumentos passados na linha de comando são interpretados

Quando se inicia o programa através da linha de comando, a JVM 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.

Para se ter mais clareza, 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) pelo CLI é essa:

Image description

Fazendo uma breve análise, a função inicia uma verificação para ver se o argumento passado se inicia com + ou -, determinando se a flag for booleana, e também se deve ser desativada ou ativada.

Image description

Depois disso, o código começa a extração do nome da flag. Cada caractere é analisado, se não for alfanumerico ou não for _, ele termina (significando que o nome da flag está completa).

Image description

Depois de fazer as verificações e identificar o nome da flag, o método JVMFlag* flag = find_jvm_flag(name, name_len); finalmente é invocado para ver se há alguma configuração disponível ao que foi fornecido.

Esse é um pequeno resumo de como os argumentos mais avançados da -XX são parseados. É possível encontrar, no entanto, nesse mesmo arquivo que irei citar, os processos de argumentos que se iniciam com -X que passam por outra função de parsing:

Image description

Exemplo da flag: -XMS

Image description

ARTIGO EM CONSTRUÇÃO

Heroku

Build apps, not infrastructure.

Dealing with servers, hardware, and infrastructure can take up your valuable time. Discover the benefits of Heroku, the PaaS of choice for developers since 2007.

Visit Site

Top comments (0)

A Workflow Copilot. Tailored to You.

Pieces.app image

Our desktop app, with its intelligent copilot, streamlines coding by generating snippets, extracting code from screenshots, and accelerating problem-solving.

Read the docs

👋 Kindness is contagious

Explore a sea of insights with this enlightening post, highly esteemed within the nurturing DEV Community. Coders of all stripes are invited to participate and contribute to our shared knowledge.

Expressing gratitude with a simple "thank you" can make a big impact. Leave your thanks in the comments!

On DEV, exchanging ideas smooths our way and strengthens our community bonds. Found this useful? A quick note of thanks to the author can mean a lot.

Okay