QMCS280 Course Syllabus

University of St. Thomas

Quantitative Methods and Computer Science Department

 

Course Number: QMCS280 03

Course Title: Object-Oriented Design and Programming

Term: Spring, 1999

Prerequisites: QMCS 130 or QMCS 237 or QMCS 238 or QMCS 234 or

QMCS240

Meeting Time: Tuesday and Thursday, 3:25 pm to 5:05 pm

Room: 250 OWS

Instructor: Joe Komar (plain old Joe will do)

Office: 406 OSS

Telephone: 962-6213 (W), 646-4457 (H)

Electronic Mail: jakomar@stthomas.edu

WWW Page: http://komar.cs.stthomas.edu

Office Hours: By Appointment (I'm almost always in when not in class!)

 

Required Textbook: Lewis, John and Loftus, William. JAVA Software Solutions: Foundations of Program Design, Addison-Wesley, 1997.

Supplemental Textbook: Eckel, Bruce, Thinking in Java The Definitive Introduction to Object-Oriented Programming in the Language of the World-Wide Web, Prentice Hall PTR, 1998

Course Objectives: Upon completion of the course, the student will be able to:

  1. Define and describe object, class, method, inheritance, polymorphism, and encapsulation.
  2. Describe the use of object oriented analysis and design tools such as class diagrams, use cases, and CRC cards.
  3. Design and code non-trivial object oriented Java programs.

Exams: There will be four exams on the dates indicated below. Each exam will be worth 100 points.

Assignments: There will be nine assignments (see below). Each of these will be worth 25 points and are due at the beginning of class on the due date. Programming assignments will be turned in on a diskette that will contain all the files necessary to run the program. It is critically important that these assignments be done correctly and on time! Students are encouraged to write additional programs given in the texts. It is only through repeated coding of programs that the language is learned effectively.

Project: There will be a group project due the day of the final exam. Groups will consist of 4 individuals, each of whom must contribute significantly to the project. A written project report (one report per group) will be submitted attesting to the fact that all members did contribute significantly. The project will be worth 150 points.

 

Communication: The preferred method of communication will be with electronic mail. Students are responsible for checking their mail at least daily. Students with questions or problems with programming assignments are encouraged to send an electronic mail message and attach the program in question. This will insure the quickest response to specific problems. There is also a "listserv" set up for the class, through which individuals can communicate directly with the rest of the members of the class. Instructions how to subscribe to this listserv will be provided in class.

Instructional Philosophy: The instructor takes full responsibility for providing the best learning resources and instructional guidance possible. It is expected that each student will take full responsibility for using these resources and this guidance to learn the maximum possible. Maximum learning is only obtained through a partnership, with each individual fully meeting their respective responsibilities.

Grading: Grading will be based on the percent of total points earned to total points possible. Total points possible will be the sum of all exams, all assignments, and the final project. The actual distribution of letter grades based on the percent will be determined at the end of the semester. However, the following would be a "typical" distribution:

92% to 100% A

88% to 91% A-

84% to 87% B+

80% to 83% B

76% to 79% B-

72% to 75% C+

68% to 71% C

64% to 67% C-

60% to 63% D+

56% to 59% D

52% to 55% D-

Below 52% F

 

Detailed Course Outline

Date Lewis & Topic(s)

Loftus Eckel

2/2 Intro to Object Orientation, WWW

2/4 1,2 2 WWW pages, Computer Systems

2/9 2 2 Java overview, OO programming

2/11 3 3 Data types, variables, assignment

2/16 3 3 I/O, operators, structures

2/18 4 3,4 Objects, classes, methods

2/23 4 1 Encapsulation, Use cases, design tools

2/25 EXAM 1

3/2 5 3 Data Internals, additional operators

3/4 5 3 Misc. operators and control structures

3/9 6 4,8 Array handling, multidimensional arrays

3/11 6 4,8 Vectors and strings, CRC cards

3/16 7 13 Graphics, color, shapes

3/18 7 13 Fonts and Graphics page

3/23 EXAM 2

3/25 8 5,6,7 Inheritance, derived classes

Date Lewis & Topic(s)

Loftus Eckel

4/6 8 5,6,7 Class hierarchies and polymorphism

4/8 9 7 Abstract classes

4/13 9 7,5 Interfaces and packages

4/15 10 13 Graphical User Interface - events

4/20 10 13 GUI components, layout managers

4/22 11 1 Software life cycle

4/27 EXAM 3

4/29 11 Design examples and exercises

5/4 14 9 Exceptions

5/6 14 14 Threads and synchronization

5/11 15 Object-oriented analysis, design

5/13 EXAM 4

5/21 (8:00 am to 10:00 am) Project Presentations

Assignments

All assignments are from the Lewis and Loftus text. The decimal number below refers to the "Programming Projects" number in the text and the whole number refers to the page number in the text.

Assignment Due Date

2.17, 72

2.24, 73

2.25, 73 2/16/99

3.19, 118 2/23/99

4.21, 169 2/25/99

5.26, 205 3/11/99

6.25, 246 3/18/99

7.21, 283 3/23/99

8.14, 327 4/15/99

9.15, 354 4/20/99

10.30, 405 4/27/99