Posts

Showing posts from March, 2012

Kotlin Language Features Related to Null Handling

Any software engineer with a Java background would find the null handling features in the Kotlin language interesting. Let's summarize this topic with some examples. Nullable types: In Kotlin, types are non-nullable by default. If you want a variable to be able to hold a null value, you need to explicitly declare its type as nullable using the Type? syntax. For example, String? denotes a nullable string, while String represents a non-nullable string. Safe calls (?.): Kotlin introduces the safe call operator (?.) for handling nullable types. It allows you to safely invoke a method or access a property on a nullable object. If the object is null, the expression returns null instead of throwing a NullPointerException. Example: data class Person(val name: String, val age: Int, val address: String?) fun main() {     // Create a person with a nullable address     val person1 = Person("John Doe", 25, "123 Main Street")     val person2 = Person("Jane Doe", 30,

Interpreter for a Subset of Java Language (J-)

In this post we will have a look at the interpreter part of my project. Before interpreting the source code, following things happened: • Lexer built the tokens from source code. • AST (Abstract Syntax Tree) was created. • Parser traversed the AST and populated our Symbol Table Interpreter should once again traverse the AST and execute the statements. private Object exec(CommonTree statement) { switch (statement.getType()) { case ProgramWalker.BLOCK: case ProgramWalker.MAINMETHOD: block(statement); break; case ProgramWalker.PRINT: print(statement); sendSourceLineMessage(statement); break; case ProgramWalker.VARDECL: currentSpace.put(statement.getChild(1).getText(), null); sendSourceLineMessage(statement); case ProgramWalker.METHOD: break; case ProgramWalker.INT: ret

Popular posts from this blog

Trie Data Structure and Finding Patterns in a Collection of Words

swapLexOrder: Finding lexicographically largest string

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