ロンドン大学で MSc Computer Science: Object-oriented programming モジュールを履修中。
講義内容に関して記録した個人的なスタディノートです。
全 12 週のうち 1〜5 週目の内容を記録します。(1 週目開始:2024 年 1 月 8 日 / 5 週目終了:2024 年 2 月 11 日)
モジュール概要 #
Aims
This module covers object-oriented programming, including the use of subclasses, modules, and library classes to create well-organised programs. A further aim is to enhance student’s understanding of making appropriate choices on the selection of algorithms, their implementation together with the required data structures (e.g. arrays, lists, trees, graphs, depth- and breadth-first search algorithms). To enable students to develop programs for modern multi-core architectures utilising functional programming constructs.
Weeks
講義は Week 10 まで。Week 11, 12 は最終課題を作成する期間。
- Week1: Transition to object-oriented
- Week2: Casting, collections and more flow control
- Week3: Object-Oriented Programming: Classes, objects, and methods
- Week4: Inheritance
- Week5: Unit Testing
- Week6: Packages and Interfaces
- Week7: Exceptions and I/O
- Week8: Concurrency
- Week9: Generics
- Week10: Lambda and method references
参考文書 #
Essential reading
- Eck, D.J. (2021). “Introduction to - programming using Java” 8th Edition.
- Schildt, H. “Java: a beginner’s guide”. (McGraw Hill, 2018) 8th edition.
- Sedgewick, R. and K. Wayne “Computer science: interdisciplinary approach”. (Addison Wesley, - 2020).
- Sierra, K. and B. Bates “Head first Java”. (O’Reilly Media, Inc, 2005).
- Whittaker, J.A., J. Arbon and J. Carollo “How Google tests software”. (Addison Wesley, 2012).
- The Java Language Environment
- The Java Tutorials
Week 1: Transition to object-oriented programming #
レクチャー内容
- Code structure, datatypes, variables, flow control, operators
- Lecture 1: Coding basics and flow control
- Your first complete Java program
- Lecture 2: Datatypes, variable scope, operators
- Labs
- Lecture 3: Hands-on programming demo
- Programming exercises: Find the max value
- Programming exercises: Middle of three
- Programming exercises: Intersecting intervals
- Programming exercises: Add one second
- Programming exercises: Reverse
- Programming exercises: String sum
- Quiz
ノート
- 既知の内容がほとんどだったため、講義内容の記録は簡略化する。
- 講義内容は Java の導入的な説明だった。
// HelloWorld.java
public class HelloWorld {
public static void main(String[] args) {
System.out.println("Hello world!");
}
}
When Java tries to execute our application, it will look for the “main” method to begin running our code.
javac HelloWorld.java && java HelloWorld
>> Hello World!
“javac” command compiles HelloWorld.java to “HelloWorld.class” file then “java” command executes “HelloWorld.class” file.
Further material #
- About the Java Technology | The Java Tutorials
- Writing Clear Code | Introduction to Programming in Java · Computer Science
- Java Programming Cheatsheet | Introduction to Programming in Java · Computer Science
Week 2: Casting, collections and more flow control #
レクチャー内容
- Casting and collections
- Lecture 1: Casting, string, arrays, ArrayLists and other collections
- Iteration
- Lecture 2: Iteration statements in Java
- Labs
- Lecture 3: Hands-on programming demo
- Programming exercises: Classification of letters
- Programming exercises: Separating by commas
- Programming exercises: The odd between
- Programming exercises: Anagrams
- Programming exercises: Roman numerals
- Programming exercises: Knight’s tour
- Quiz
ノート
- 既知の内容がほとんどだったため、講義内容の記録は簡略化する。
- 講義内容は前回に引き続き Java の文法などの説明だった。各種データ型や、分岐、ループ処理など。
Week 3: Object-oriented programming: classes, objects, and methods #
レクチャー内容
- Classes and objects
- Lecture 1: Classes and objects
- Methods and constructors
- Lecture 2: Methods, constructors and overloading
- Access control, nested and inner classes
- Lecture 3: Access control, nested and inner classes
- Labs
- Lecture 4: Hands-on programming demo
- Programming exercises: Bank account
- Programming exercises: Dates
- Programming exercises: Triplicate
- Programming exercises: Centered numbers
- Quiz
ノート
- 既知の内容がほとんどだったため、講義内容の記録は簡略化する。
- 講義内容は前回に引き続き Java の文法などの説明だった。クラス、オブジェクト、メソッドやオーバーロードなど。
Memory management
- When
new
is used an object is dynamically allocated from a pool of free memory. new
may fail due to insufficient free memory.- When objects are no longer used, the memory allocated should be freed.
- Java employs garbage collection.
- When there are no references to an object, the object is released.
- It’s possible to specify what happens before an object is released using
finalize()
.
Week 4: Inheritance #
レクチャー内容
- Inheritance
- Lecture 1: Inheritance, constructors and using superclass methods
- Overriding and dynamic dispatch
- Lecture 2: Overriding and dynamic dispatch
- Labs
- Lecture 3: Hands-on programming demo
- Programming exercises: Rectangles
- Programming exercises: Squares
- Programming exercises: Chess attack
- Programming exercises: Poker face
- Quiz
ノート
- 既知の内容がほとんどだったため、講義内容の記録は簡略化する。
- 講義内容は前回に引き続き Java の文法の説明が主だった。抽象クラス、継承、オーバーライドや動的ディスパッチなど。これに加えて、IntelliJ IDEA の導入に関しての説明もあった。
Dynamic dispatch
オブジェクトのメソッド呼び出しを コンパイル時の型ではなく実行時の型により決定する仕組み。
- 動的バインディング、ダイナミックバインディング - Wikipedia
- https://ja.wikipedia.org/wiki/%E3%83%80%E3%82%A4%E3%83%8A%E3%83%9F%E3%83%83%E3%82%AF%E3%83%90%E3%82%A4%E3%83%B3%E3%83%87%E3%82%A3%E3%83%B3%E3%82%B0
Further material #
- Composition over Inheritance - Fun Fun Function | YouTube
- Banana, Gorilla, Jungle problem
-
The problem with object-oriented languages is they’ve got all this implicit environment that they carry around with them. You wanted a banana but what you got was a gorilla holding the banana and the entire jungle.
Joe Armstrong (the creator of Erlang)
- 「オブジェクト指向言語の問題点は、暗黙的な環境をすべて持ち回ることです。あなたはバナナが欲しかったのですが、手に入れたのはバナナとジャングル全体を抱えたゴリラでした。」これは主として継承の問題点を指摘している。
-
Week 5: Unit testing #
レクチャー内容
- JUnit
- Lecture 1: Using JUnit classes to test Java programs
- How to organise testing using JUnit classes
- Lecture 2: Testing strategies
- Labs
- Lecture 3: Hands-on programming demo
- Programming exercises: Replace Checkers with Unit tests
- Quiz
ノート
- 既知の内容がほとんどだったため、講義内容の記録は簡略化する。
- 講義内容は JUnit を用いた Java コードのユニットテストについて。
Java annotations
- Are a form of metadata i.e. provide data about a program but not part of the program itself.
- Used by the compiler to detect errors or suppress warnings.
@SuppressWarnings("deprecation")
- Software tools can process them to generate code, XML files, and so forth.
JUnit
import org.junit.Test;
import static org.junit.Assert.*;
public class MainTest {
@Test
public void testStrings()
{
String a = "Hi";
String b = "there";
String c = "Hi there";
assertEquals(a + b, c);
}
}
// To check an exception is thrown.
@Test(expected = NullPointerException.class)
public void testNull()
{
String test = null;
test.length();
}
Testing strategies
1 - Test “extreme” values:
- Test that “small values” are processed correctly:
- int: -1, 0, 1
- positive int: 1, 2, 3
- List: empty, single element
- String: empty string, string of length 1
- Day of year: first day of year
- Test that “large values” are processed correctly:
- int: Integer.MIN_VALUE, Integer.MAX_VALUE
- Lists with many elements
- Strings of high length
- Day of year: last day of year
2 - Test a mix of inputs:
- For a method that receives multiple ints, test that it works when we mix together:
- big and small values
- negative and positive values
- duplicate/equal values
- values close to each other
- Apply this ideas to other datatypes e.g. for strings
- long and short (in terms of length)
- textually equal
- almost textually equal etc
3 - Test unexpected/malformed inputs:
- For a method that expects a String holding an email address, what happens when the string does not contain an @ character?
- What happens when a negative int is passed to a method that expects positive int