This notional machine represents a source code expression
in the form of a tree.
This makes the structure of the expression explicit,
and it allows visualizing the various steps of expression evaluation.
It also allows annotating the various subexpressions with their types.
An expression tree is essentially an abstract syntax tree (AST),
focused on just an expression.
Here is an example Java expression:
The corresponding expression tree
shows not only the expression’s structure
but also the types and values of all subexpressions:
A notional machine focuses on a subset of the syntax and semantics of a programming language. The following misconceptions are related to the language features expressible in this notional machine.
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Addition has higher precedence than string concatenation
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Parenthesis are used to access an element in an array
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Arrays are created without the new keyword
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
The number of brackets in an array type or an array initializer corresponds to the length of the array
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
The type of a multi-dimensional array is written as T[] T[] T[]
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
To get the length of an array, one needs to call its length method
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Array initializers list the elements in square brackets
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Array rank and array length are the same thing
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
= compares two values
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
An assignment a=b is not an expression
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
One can invoke a method on primitive values
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
One needs a variable to invoke a method
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Member accesses cannot be chained together
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Method calls or field accesses cannot be chained to a constructor invocation
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Chained methods are all called on the object at the beginning of the chain
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Char is not a numeric type
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
To test whether an expression evaluates to true or false, one must compare it to a constant
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
To test whether an expression is True or False, one must compare it to True or to False
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
To test whether an expression is true or false, one must compare it to true or to false
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Expressions that consist of multiple parts have no type
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
One can write the constructor name, without new, to instantiate a class
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Evaluating an expression means outputting its result
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
An expression that reads a variable also updates its value after the evaluation
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
One has to evaluate an expression to determine its type
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
The expression tree of an expression involving a call inlines the call's computation of the returned value
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
The expression tree of an expression involving a variable inlines the variable's definition
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Dividing two integers can produce a rational number
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
A literal is not an expression
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
When passing a literal string as argument to a method, no quotes are needed
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
To map a boolean expression to a boolean, a conditional operator is necessary
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
To map a boolean expression to a bool, a ternary conditional operator is necessary
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
A reference variable can point to multiple objects
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
A variable can contain more than one value
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
A multi-dimensional array is one thing
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Expressions must consist of more than one piece
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
One cannot invoke methods on String literals
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
If a variable is at least as big (bit-width) as a value, then no cast is needed to a assign the value to the variable
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
An object contains only the fields declared in its class
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
There are no float literals
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Smaller types are never automatically converted into bigger ones without an explicit cast
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Multi-dimensional arrays have a rectangular shape
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
There are no long literals
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Subclasses inherit fields but not methods
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
&& and || always evaluate both operands
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
and/or always evaluate both operands
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
& is only a bitwise AND
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
One cannot invoke toString() on a String
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
NullPointerExceptions are detected at compile time
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Numeric types can be coerced to boolean
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
A variable is needed to instantiate an object
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Only the elements of the innermost array of a multi-dimensional array are accessible
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Out-of-bounds array elements are null
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Nested function calls are invoked outside in
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Nested method calls are invoked outside in
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
() are optional for method calls without arguments
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
() are optional for function calls without arguments
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
The type of a primitive variable depends on its value
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Private members of a superclass are accessible from a subclass
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Rational fractions are literals
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Every reference type can be coerced to boolean
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
One can cast between references and ints
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Chained accesses are invoked from right to left
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
The name self is not an expression
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
String literals can be in single quotes
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
One can know the length of a String object by accessing its length field
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
One needs to call the String constructor to get a String object from a literal
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
String concatenation stringifies non-String operand expressions
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
The multiplication operator can repeat a String a number of times
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
To call a method on a superclass, parentheses are needed after the keyword super
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
The type of a numerical expression depends on the type expected by the surrounding context
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
One can assign to this
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
this can be null
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Instance method or constructor call nodes in expression trees have a child labeled "this"
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
In a constructor, this is null
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
The name this is not an expression
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
Invoking toString() prints something
data:image/s3,"s3://crabby-images/91f5f/91f5ff41ddd5d79d3a8e78ece9c4401fcf5c146b" alt="Misconception"
= stores an expression in a variable