Java Programming

Location: Room 223B, 德田館
Time: 0900 ~ 1200, Saturday and Sunday


``Java is C++ without the guns, knives, and clubs.''
-- James Gosling, co-inventor of Java (1955-)

Objectives

This course is designed for the students who want to learn Java but have any programming experiences before. We will start with the very beginning of program design and fundamental concepts about programs and machines. You are expected to be capable to implement your idea in Java independently after 30 hours of lectures. Furthermore, I wish you could learn other programming languages without suffering from starting over.

Prerequisites

Text

References

Java (introductory level)

Java (advanced level)

Data structures and algorithms

Object-oriented analysis and design

Computer organization/architecture

Related courses

Misc

Additional reading

Installation & Wifi

Overview

Procedural programming

Object-oriented programming

Utilities

Data structures and algorithms

Design patterns

Schedule [ 247, 250, 251, 252, 253, 254, 255, 260, 261, 263, 265, 266, 268, 269, 271, 274, 275, 276, 277, 278, 280, 281, 281n, 282, 283, 284, 286, 289, 290, 291, 292, 293, 294 ]

Date Summary
2018.1.13 programs, computational solutions, computer systems (CPUs, memory, memory hierarchy), programming languages (high-level, assembly, machine code), algorithms, JDK + Eclipse, first Java program;
2018.1.14 variables, data types (int, double, char, boolean) (see Some disasters attributable to Numerical Analysis), arithmetic operators (+, -, *, /, %), assignment operator (=), type conversion, rational operators (>, <, ==); HW0: Lab 0 due 1/20;
2018.1.20 logical operators (!, &&, ||, ^), compound operators (+=, ++), reference types, Scanner object, selections (if-else if-else, switch-case, ?: operator), loops (while, do-while, for);
2018.1.21 jump statements, nested loops; HW1: Lab 2 due 1/27;
2018.1.27 analysis of algorithms, arrays;
2018.1.28 for-each loops, briefing data structures, sorting algorithms, searching algorithms, higher-dimensional arrays, methods; HW2: case (C) and case (D) in PrintStarsDemo and bubble/insertion sort in comparison with selection sort due 2/3;
2018.2.3 call stack, scope of variable, method overloading, recursion (also read this; see more examples: ch18-recurex), classes & objects, fields;
2018.2.4 methods, encapsulation, constructors, this operator, static members, garbage collection, HAS-A relationship (aggregation), memory and objects, IS-A relationship, inheritance, method overriding, binding, (subtype) polymorphism; HW3: Lab 3 and 4 due 2/10;
2018.2.10 up/down casting, instanceof operator, final variable/method/class, abstract classes/methods, interfaces, wrapper classes, immutable objects, enum typesnamespace, nested classes, anonymous classes, iterators, packages, classpath, JAR, assertion and exception handling, strings, regular expressions (see regex by Oracle, or regexp, regex crossword);
2018.2.11 file I/O, events, listeners, callbacks, Java graphics and GUIs, Java event handling, Java 2D games tutorial (see snake game), JavaFX tutorial;

Sample code

Homework

Gradebook