Skip to content

jooskesters/ogp-notes

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Object-Oriented Programming

Single-object abstractions

Inheritance

  • Polymorphism
    • Concepts: abstract classes, polymorphism, subclassing, inheritance, instanceof, the static type checker, static/dynamic type of a variable or an expression, typecasts, pattern matching; class Object, autoboxing and -unboxing
  • Dynamic binding
    • Concepts: dynamic binding, abstract methods, method overriding, @Override; methods equals, hashCode, toString, getClass; record classes
  • Behavioral subtyping: modular reasoning about programs that use dynamic binding
    • Example: intlist_inheritance
    • Concepts: Non-modular reasoning, modular reasoning, method specifications, correctness of methods; method call resolution, resolved method vs called method, static versus dynamic method call binding; strenghtening of specifications, behavioral types, behavioral subtyping
  • Interfaces
    • Concepts: interfaces, multiple inheritance, static fields, the Singleton pattern
  • Implementation inheritance
    • Concepts: Inheritance of fields and methods, super constructor calls, super method calls
  • Lists, sets, and maps
    • Concepts: the List, Set, and Map abstract datatypes (ADTs); the ArrayList, LinkedList, HashSet, and HashMap data structures; the Java Collections Framework

Multi-object abstractions (= entity-relationship abstractions)

Advanced topics

(Students of course H02C5A can ignore this material.)

  • Iterators
    • Concepts: (external) iterators, iterables, nested classes, inner classes, local classes, anonymous classes, enhanced for loop, internal iterators, lambda expressions, capturing outer variables, effectively final variables
  • Streams (on the web)
    • Concepts: streams, sources, map, filter, reduce, collect, parallel streams
  • Generics
    • Concepts: generic class, generic interface, type parameter, type argument, generic type instantiation, parameterized type, bounded type parameter, covariance, contravariance, invariance, upper-bounded wildcard, lower-bounded wildcard, generic method, erasure, unchecked cast warning

Packages

No packages published

Languages

  • Shell 100.0%