Posts

Showing posts from January, 2012

Observability of the Java Virtual Machine

Image
The JVM is one of the most observable runtimes. It provides us lots of tools for troubleshooting a JVM application in production. 1. Thread observability Threads are how the JVM actually does work. When something is wrong in production, the symptom is almost always a thread: stopped, blocked, leaking etc. Thread dumps work on any JVM with no  instrumentation, no agents, no restarts. <Example project link with /threaddump endpoint>         // (1) Deadlock — two threads grab the same pair of locks in opposite order.         new Thread(() -> grab(LOCK_A, LOCK_B), "deadlock-A-then-B").start();         new Thread(() -> grab(LOCK_B, LOCK_A), "deadlock-B-then-A").start(); http://localhost:8080/actuator/threaddump To list the JVMS, we can use the command below. PS C:\observe-jvm> jps -lv 25296 jdk.jcmd/sun.tools.jps.Jps -Dapplication.home=C:\Program Files\Microsoft\jdk-21.0.3.9-hotspot -Xms8m -Djdk.module.main=...

A Code Analyzer for a Subset of Java Language (J-) Using ANTLR - PART 2

As we know, semantic analysis of a compiler includes checking the types of expressions. To do that, we have to maintain a Symbol Table which maps variable names to their types and locations. There maybe many variables with the same name which are in different scopes. This is legal in most languages and we have to handle this situation. We have to know when following scopes are entered in: - class scope - method scope - no inner block scopes (my language does not support this currently) We will do type-checking in two phases. First we'll populate the Symbol Table and it will contain the symbols with their scopes. Then, we'll check the types of symbols that are subject to addition operation by querying the symbol table. ANTLR allows us to inject code in different places of the generated parser. We need to know when a class/method scope is entered and the end of any scope is reached. Below is some grammar code from the project : classDecl @init {visitor.beforeClass(); System.out.p...

A Code Analyzer for a Subset of Java Language (J-) Using ANTLR - PART 1

Our goal is to write a code analyzer for a language that is called "J minus". Source code of the whole project can be found here: https://code.google.com/p/j-minus/ Lets start with the language definition: Lexical Rules: Identifiers: Sequence of letters. Integer literals: A sequence of decimal digits. Binary operators: && Grammar Rules: Program -> MainClass ClassDecl* MainClass -> class id { public static void main (String [] id) { Statement* }} ClassDecl -> class id { VarDecl* MethodDecl* } VarDecl -> Type id ; MethodDecl -> public Type id ( ( formalParameter (, formalParameter)* )? ) { varDecl* statement* return exp; } FormalParameter -> Type id Statement -> id = Exp; Exp -> AdditionExp | SimpleExp SimpleExp -> id | int AdditionExp -> SimpleExp + SimpleExp Type: 'int' | 'boolean' ; We must pass following steps to reach our goal: 1) Implement the lexer and parser for the language. (use ANTLR) 2) Build the Abs...

"Parsing" Konusu ile ilgili Temel Kavramlar

--Halen yazım aşamasında-- Regular expressions yardımıyla bir programın "lexical" yapısını ifade edebildiğimizi görmüştük. Aynı şeyi dildeki cümleler için yapmak mümkün mü? Dildeki cümlelerin yapısını ifade etmek için "context free grammar" kavramı kullanılmakta. Dildeki karmaşık yapıları oluşturmak için "production" yaparak ilerlemek gerekiyor. Aşağıda 5 tane production ile ifade edilen bir dili inceleyelim: S -> S ; S S -> ID = E E -> E + E E -> ID E -> NUM Bu kuralları kullanarak bir cümle üretmeye çalışalım: S ; S ID = E ; ID = E ID = E + E; ID = E ID = ID + NUM; ID = NUM Burada ürettiğimiz cümlenin kaynak kodu (lexer ele almadan önce) şöyle olabilirdi: var = i + 4; j = 5 Burada tokenlerin değerleri: var, i, j, 4, 5 Token türleri: ID, NUM, "+", ";", "=" Gramer ifadesinde sağ tarafta bulunamayan sonlanmış semboller dikkati çekiyor. Bunlara "terminal symbol" deniliyor. Terminal semboller, token tür...

Popular posts from this blog

The WeakReference class, monitoring memory leak and garbage collection in a Java application

Simplescalar Simulator - Part 2: sim-outorder.c

Notes on Java Performance