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

Image
 Below is a Stack implementation that uses an internal resizeable array structure.  public class MyStack< T > implements Stack< T > { private static final int CAPACITY = 100 ; private Object[] array ; private int pos = 0 ; public MyStack () { this . array = new Object[ CAPACITY ] ; } @Override public void push ( T item) { if ( pos >= array . length / 2 ) { Object[] newArray = new Object[ pos * 2 ] ; System. arraycopy ( array , 0 , newArray , 0 , array . length ) ; array = newArray ; } array [ pos ++] = item ; } @Override public T pop () { if (isEmpty()) { throw new RuntimeException( "empty stack" ) ; } @SuppressWarnings ( "unchecked" ) T item = ( T ) array [ pos - 1 ] ; pos -= 1 ; return item ; } @Override @SuppressWarnings ( "unchecked" ) public T peek...

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 Abstract Syntax Tree (AST) using the parser.
3) Create a tree walker for the AST
4) Create and populate a Symbol Table
5) Perform type-checking analysis

-- to be continued

Comments

Popular posts from this blog

Trie Data Structure and Finding Patterns in a Collection of Words

My Crappy Looking Solution to "Binary Tree Common Ancestor" Problem

A Graph Application in Java: Using WordNet to Find Outcast Words