| Department of Computer Science and Engineering Home Lectures Labs and Lab Solutions Detailed List of Concepts Test Solutions Useful Links 
 
 | Intended Learning Outcomes
Here you will find a very detailed list of intended learning outcomes
for each chapter of the Course Notes.
 
Items marked with an asterisk (*) may not be covered.
 Chapter 1 Implementing Static Features
	identify, correctly use, and
	implement utility classesexplain what the static modifier
	means for attributes and methodsuse and draw UML diagrams for
	utility classesdraw memory diagrams for
	utility classesdefine what the access
	modifiers public and private mean for attributes and methodsexplain how the choice of
	access modifier affects encapsulationdefine what the final modifier
	means for attributes 
	explain why utility classes
	have a private constructorimplement static attributes for
	a utility classimplement static methods for a
	utility classwrite tests for static methodsexplain the difference between
	arguments and parametersexplain how local variables can
	shadow class attributesexplain the difference between
	preconditions and validationimplement static methods that
	use parameter validationadd documentation to a utility
	class using Javadocimplement static methods having
	interfaces as parametersimplement static methods having
	generics as parameters* Chapter 2 Implementing Non-static
Features
	define what a class is in Javadefine what the this keyword
	means in Javaexplain how non-static attributes and methods differ from
	    static attributes and methodsuse and draw UML diagrams of
	classesdraw memory diagrams for
	classesdefine what a constructor is in
	Javadefine what a default
	constructor is in Javadefine what a copy constructor
	is in Javaimplement constructors for a
	classimplement constructor chaining
	for a classdefine what an accessor method
	isdefine what a mutator method isimplement accessor and mutator
	methods for a classdefine what the toString method
	is used forimplement the toString method
	for a classdefine what the equals method
	is used forimplement the equals method for
	a classdefine what the compareTo
	method is used forimplement the compareTo method
	for a classwrite tests for non-static
	methodsdefine what an immutable class
	is (and why they are useful)implement an immutable classdefine what a class invariant
	is (and why they are useful)describe when a class invariant
	must be truedefine what the hashCode method
	is used forimplement the hashCode method
	for a classimplement methods that use
	parameter validationadd documentation to a class
	using Javadocimplement methods having
	interfaces as parametersimplement methods having
	generics as parameters* Chapter 3 Mixing Static and
Non-static Features
	implement a class that can
	count the number of objects createdimplement a class that stamps
	serial numbers on objectsimplement a class that uses the
	singleton patternimplement a class that enforces
	one instance per state Chapter 4 Implementing Aggregation
and Composition
	define aggregationdefine compositionuse and draw UML diagrams for
	classes that use aggregation and compositiondraw memory diagrams for
	classes that use aggregation and compositionexplain the differences in
	constructors and methods between classes that use aggregation and
	classes that use compositionimplement classes that use
	aggregationimplement classes that use
	compositioncontrast aliasing, shallow
	copying, and deep copying Chapter 5 Implementing Inheritance
	use and draw UML diagrams for
	classes that use inheritancedraw memory diagrams for
	classes that use inheritancedefine what a superclass (or
	parent class) isdefine what a subclass (or
	child class) isstate what features are
	inherited by subclassesdefine what the keyword extends
	means in Javadefine what the keyword super
	means in Javaimplement constructors for a
	subclassdefine what an overridden
	method isimplement overridden methods
	for a subclassexplain how preconditions,
	postconditions, and throws clauses behave in an inheritance
	hierarchydefine what the final modifier
	means for methodsdefine what the final modifier
	means for classesdefine what an abstract class
	isdefine what an abstract method
	isimplement an abstract classdefine what an interface is in
	Javaimplement an interface Chapter 6 Implementing Graphical
User Interfaces
	define what the model is in the
	model-view-controller (MVC) patterndefine what the view is in the
	MVC patterndefine what the controller is
	in the MVC patterndraw the UML diagram for the
	MVC patterndefine what event-driven
	programming isimplement a graphical user
	interface (GUI) using MVC Chapter 7 Recursion
	identify base cases for a
	recursive algorithmidentify recursive cases for a
	recursive algorithmimplement a recursive algorithm
	in Java to solve a problemderive a proof of correctness
	for a recursive algorithmderive a proof of termination
	for a recursive algorithmsolve a recurrence relation* Chapter 8 Arrays and Data Structures
	define what an array iscreate and use arraysimplement a List using an arrayimplement an iterator for a
	class that models a collectionimplement a recursive data structure such as a linked list
	    or tree*implement a stack*implement a queue*understand the basic operations on recursive data structures
	    such as linked lists and binary trees*understand the basic operations on stacks and queues* |