COMP2511

24T3 Week 3

Tuesday 3PM - 6PM (T15A)

 Thursday 11AM - 2PM (H11C)

 

Slides by Christian Tolentino (z5420628)

Today

  • Polymorphism/Inheritance
  • Code Review
  • UML
  • Exceptions
  • JUnit testing1

Important Notice

  • Assignment-i is out, please start early
  • Go to help sessions if you need help (they get busier towards the due date)
  • No auto generated UMLs of any sort. You will get 0. If you use programs that generate it based on text, please commit this text as a file in your repo.
  • Assignment-ii pair preferences are out. I will be posting a preference link soon on Teams.

Polymorphism

Polymorphism

An object's ability to decide what method to apply to itself, depending on where it is in the inheritance hierarchy, is usually called polymorphism.

What is it?

Group Task

Code Review - 5 minutes

Code Review

  1. Can you override a static method?
  2. What is the output of A.f()?
public class A {
    public static void f() {
        C c = new C();
        c.speak();
        B b = c;
        b.speak();
        b = new B();
        b.speak();
        c.speak();
    }
}


public class B {
    public void speak() {
        System.out.println("moo");
    }
}


public class C extends B {
    public void speak() {
        System.out.println("quack");
    }
}
public class D {
    public static void f() {
        F f1 = new F();
        F f2 = new F();
        f1.incX();
        f2.incY();
        System.out.println(f1.getX() + " " + f1.getY());
        System.out.println(f2.getX() + " " + f2.getY());
    }
}

public class F {
    private int x;
    private static int y;

    public int getX() {
        return x;
    }

    public int getY() {
        return y;
    }

    public void incX() {
        x++;
    }

    public void incY() {
        y++;
    }
}

3. What is the output of D.f()

Code Review

  1. Can you override a static method?
    • No, since the static method is attached to the class, it cannot be overridden
  2. What is the output of A.f()?
    • ​​quack
    • quack
    • moo
    • quack
public class A {
    public static void f() {
        C c = new C();
        c.speak();
        B b = c;
        b.speak();
        b = new B();
        b.speak();
        c.speak();
    }
}


public class B {
    public void speak() {
        System.out.println("moo");
    }
}


public class C extends B {
    public void speak() {
        System.out.println("quack");
    }
}

Code Review

What is the output of D.f()

public class D {
    public static void f() {
        F f1 = new F();
        F f2 = new F();
        f1.incX();
        f2.incY();
        System.out.println(f1.getX() + " " + f1.getY());
        System.out.println(f2.getX() + " " + f2.getY());
    }
}

public class F {
    private int x;
    private static int y;

    public int getX() {
        return x;
    }

    public int getY() {
        return y;
    }

    public void incX() {
        x++;
    }

    public void incY() {
        y++;
    }
}
1 1
0 1

Domain Modelling

UML

UML

UML

UML

Composition is a specialized form of aggregation. In composition, if the parent object is destroyed, then the child objects also cease to exist. Composition is actually a strong type of aggregation and is sometimes referred to as a "death" relationship.

Cardinalities

Domain Modelling

Create an OO domain model for a system with the following requirements.

A Car has one or more engines and a producer. The producer is a manufacturing company who has a brand name. Engines are produced by a manufacturer and have a speed. There are only two types of engines within UNSW's cars:

  • Thermal Engines, which have a default max speed of 114, although they can be produced with a different max speed, and the max speed can change to any value between 100 and 250.
  • Electrical Engines, which have a default max speed of 180. This is the speed at which they are produced, and the max speed can change to any value that is divisible by 6.

Cars are able to drive to a particular location x, y.

Since UNSW is a world-leader in technology innovation, they want you to be able to model the behaviour of Time Travelling for any vehicle, and to model a time travelling car. A vehicle that travels in time stays in the same location but travels to a LocalDateTime.


Domain Modelling

Create an OO domain model for a system with the following requirements.

A Car has one or more engines and a producer. The producer is a manufacturing company who has a brand name. Engines are produced by a manufacturer and have a speed. There are only two types of engines within UNSW's cars:

  • Thermal Engines: which have a default max speed of 114, although they can be produced with a different max speed, and the max speed can change to any value between 100 and 250.
  • Electrical Engines: which have a default max speed of 180. This is the speed at which they are produced, and the max speed can change to any value that is divisible by 6.

Cars are able to drive to a particular location x, y.

Since UNSW is a world-leader in technology innovation, they want you to be able to model the behaviour of Time Travelling for any vehicle, and to model a time travelling car. A vehicle that travels in time stays in the same location but travels to a LocalDateTime.

 

LucidCharts

A generally good diagram maker software that is free*

 

*if you sign up with an .edu account

Common mistakes

  • Wrong types of arrows and lines used.
  • Missing cardinalities and/or no aggregation/composition relationship identified
  • No way to differentiate between abstract classes, interfaces and a regular class - you can either use different font, italicise, bold or even just labelling it.
  • Not using + to indicate public and - to indicate private

 

When I mark, these sort of mistakes lose 0.5 - 1 mark each.

 

Try making a draft one before you start coding your assignments

Code Demo

Wonderous.java

package wondrous;

import java.util.ArrayList;
import java.util.List;

public class Wondrous {
    private final int MY_MAGIC_NUMBER = 42;

    public List<Integer> wondrous(int start) {
        int current = start;
        List<Integer> sequence = new ArrayList<Integer>();

        while (current != 1) {
            sequence.add(current);
            if (current % 2 == 0) {
                current /= 2;
            } else {
                current = (current * 3) + 1;
            }
        }

        return sequence;
    }
}

The Wondrous Sequence is generated by the simple rule:

  • If the current term is even, the next term is half the current term.
  • If the current term is odd, the next term is three times the current term, plus 1

JUnit Testing

JUnit Testing

Make sure your VSCode is open in the correct folder, otherwise, these buttons wont appear

JUnit Testing

Make sure your VSCode is open in the correct folder, otherwise, these buttons won't appear

JUnit Testing

  • Failed test output
  • See past history

Debug Mode

  • Set a breakpoint, run the test in debug mode
  • Stops at a breakpoint it encounters
  • See variable values, call stack

Debug Mode

Now lets fix it

package wondrous;

import java.util.ArrayList;
import java.util.List;

// If the current term is even, the next term is half the current term.
// If the current term is odd, the next term is three times the current term, plus 1.
public class Wondrous {
    public List<Integer> wondrous(int start) {
        int current = start;
        List<Integer> sequence = new ArrayList<Integer>();

        while (true) {
            sequence.add(current);
            if (current == 1) {
                break;
            } else if (current % 2 == 0) {
                // Even
                current /= 2;
            } else {
                // odd
                current = (current * 3) + 1;
            }
        }
        return sequence;
    }
}

Exceptions

Exceptions

What are they?

  • An exception is an event, which occurs during the execution of a problem, that disrupt the normal flow of the program's instructions
  • When error occurs, an exception object is created and given to the runtime system. This is called throwing an exception
  • The runtime system searches the call stack for a method that contains a block of code that can handle the exception
  • The exception handler chosen is said to catch the exception

Exceptions

Checked vs Unchecked

  • Checked: Must be checked, will result in compilation error if not handled
    • Any class that inherits from `Exception` is a checked exception.
    • E.g., IOException, SQLException
  • Unchecked: Genuine errors that occur at run time
    • Any class that inherits from `RuntimeException` is unchecked
    • E.g., ArrayIndexOutOfBoundsExceptions, ArithmeticException

Exceptions - Wonderous

How can we use it in Wonderous to make the code better?
Checked or Unchecked?

Exceptions - Wonderous

How can we use it in Wonderous to make the code better?

package wondrous;

import java.util.ArrayList;
import java.util.List;

// If the current term is even, the next term is half the current term.
// If the current term is odd, the next term is three times the current term, plus 1.
public class Wondrous {
    public List<Integer> wondrous(int start) {
        int current = start;
        List<Integer> sequence = new ArrayList<Integer>();

        if (start < 1) {
            throw new IllegalArgumentException("wondrous start must be >= 1");
        }

        while (true) {
            sequence.add(current);
            if (current == 1) {
                break;
            } else if (current % 2 == 0) {
                // Even
                current /= 2;
            } else {
                // odd
                current = (current * 3) + 1;
            }
        }
        return sequence;
    }
}

JUnit Testing

Lets write some more tests

package wondrous.test;

import static org.junit.Assert.assertThrows;
import static org.junit.jupiter.api.Assertions.assertEquals;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

import org.junit.jupiter.api.Test;

import wondrous.Wondrous;

public class WondrousTest {
    @Test
    public void testBasic() {
        Wondrous w = new Wondrous();
        List<Integer> expected = new ArrayList<Integer>(Arrays.asList(3, 10, 5, 16, 8, 4, 2, 1));

        assertEquals(expected, w.wondrous(3));
    }

    @Test
    public void testOne() {
        Wondrous w = new Wondrous();
        List<Integer> expected = new ArrayList<Integer>(Arrays.asList(1));
        assertEquals(expected, w.wondrous(1));
    }

    @Test
    public void testInvalid() {
        Wondrous w = new Wondrous();

        assertThrows(IllegalArgumentException.class, () -> {
            w.wondrous(0);
        });
    }
}

COMP2511 Week 3 24T3

By Christian Tolentino

COMP2511 Week 3 24T3

  • 316