CSIS 370 Object-Oriented Analysis & Design


Course Description

A study of the fundamental concepts of object-oriented programming, including data abstraction and typing, encapsulation, single and multiple inheritance, substitutability, static and dynamic polymorphism, generics, interfaces, and design patterns. Object-oriented solutions will be designed using UML class and sequence diagrams and implemented in one or more high-level languages.


Instructor

Brian R. Snider
Office hours: Wood-Mar 222 (see schedule)


Texts

required
optional


Resources


Objectives

This course explores the object-oriented programming paradigm in detail. Object-oriented programming is a shift in the way programs are designed as well as implemented.

Students will understand the difference between traditional structured programming design and implementation and object-oriented design and implementation. Specifically, students will understand and be capable of appropriately using:

Students will be familiar with an object-oriented design methodology (for example, using the Unified Modeling Language—UML).

Students will utilize one or more object-oriented programming languages to develop object-oriented solutions to programming problems.


Course Organization

Object-oriented programming is both a way of thinking and conceptually designing software, as well as a programming methodology. Thus this course will devote an equal amount of time to understanding the object-oriented design paradigm as well as object-oriented programming. A well-designed object-oriented model is easily translated into any number of programming languages that support object-oriented concepts, while a poorly-designed model can result in endless difficulties—regardless of the power of the implementation language or the skill of the programmer.

The course will include regular homework and/or programming assignments. There will be no credit given for late assignments (without an excused absence)—turn in as much as you can. Unless otherwise specified, no handwritten work will be accepted.

Reading should be completed before the lecture covering the material per the provided schedule. Not all reading material will be covered in the lectures, but you will be responsible for the material on homework and exams. Quizzes over the assigned reading may be given at any time.


Collaboration and Academic Integrity

See the GFU CS/IS/Cyber policies for collaboration and discussion of collaboration and academic integrity. Most students would be surprised at how easy it is to detect collaboration or other academic integrity violations such as plagiarism in programming—please do not test us! Remember: you always have willing and legal collaborators in the faculty. We encourage you visit office hours, ask questions in class, and use the class mailing list for assistance.

Unless otherwise specified (e.g., for a group assignment or project), you are expected to do your own work. This also applies to the use of online resources (e.g., StackOverflow). Put simply: if you are representing someone else's work as your own, you are being dishonest. Any suspected incidents of academic integrity violations will be investigated and reported to the Academic Affairs Office as they arise.

Almost all of life is filled with collaboration (i.e., people working together). Yet in our academic system, we artificially limit collaboration. These limits are designed to force you to learn fundamental principles and build specific skills. It is very artificial, and you'll find that collaboration is a valuable skill in the working world. While some of you may be tempted to collaborate too much, others will collaborate too little. When appropriate, it's a good idea to make use of others—the purpose here is to learn. Be sure to make the most of this opportunity but do it earnestly and with integrity.


University Resources

If you have specific physical, psychiatric, or learning disabilities and require accommodations, please contact Disability & Accessibility Services as early as possible so that your learning needs can be appropriately met. For more information, go to georgefox.edu/das or contact das@georgefox.edu).

My desire as a professor is for this course to be welcoming to, accessible to, and usable by everyone, including students who are English-language learners, have a variety of learning preferences, have disabilities, or are new to online learning systems. Be sure to let me know immediately if you encounter a required element or resource in the course that is not accessible to you. Also, let me know of changes I can make to the course so that it is more welcoming to, accessible to, or usable by students who take this course in the future.

The Academic Resource Center (ARC) on the Newberg campus provides all students with free writing consultation, academic coaching, and learning strategy review (e.g., techniques to improve reading, note-taking, study, time management). During the 2022 fall semester, the ARC is offering in-person appointments as well as virtual appointments over Zoom as needed. The ARC, located on the first floor of the Murdock Library, is open from 1:00–10:00 p.m., Monday through Thursday, and 12:00–4:00 p.m. on Friday. To schedule an appointment, go to the online schedule at arcschedule.georgefox.edu, call 503-554-2327, email the_arc@georgefox.edu, or stop by the ARC. Visit arc.georgefox.edu for information about ARC Consultants' areas of study, instructions for scheduling an appointment, learning tips, and a list of other tutoring options on campus.


Health and Safety Considerations

Please review the entirety of the university's official COVID-19 web page for the most up-to-date community guidance.


Grading

Grading Scale

The final course grade will be based on:

Graded course activities will be posted to Canvas. Take care to read the specifications carefully and proceed as directed. Failure to pay attention to detail will often result in few to zero points being awarded on a given activity.

Grades will be updated as often as possible; you are encouraged to use the "What-If" functionality to calculate your total grade by entering hypothetical scores for various items.

Note that some graded activities in this course will be submitted via GitLab.


Tentative Schedule

Week 1 · 1/10

Introduction

C++: Ch. 1.1–1.4

Week 1 · 1/12

C++ Primitive Types

C++: Ch. 2.1–2.2

Week 1 · 1/14

C++ Compound Types

C++: Ch. 2.3

Week 2 · 1/17

Martin Luther King, Jr. Day — no classes

Week 2 · 1/19

C++ Constants

C++: Ch. 2.4–2.5

Week 2 · 1/21

C++ Library Types

C++: Ch. 3.1–3.4

Week 3 · 1/24

C++ Arrays

C++: Ch. 3.5–3.6

Week 3 · 1/26

C++ Expressions and Statements

C++: Ch. 4–5

Week 3 · 1/28

C++ Functions and Exception Handling

C++: Ch. 6, 18.1

Week 4 · 1/31

Introduction to OOP and UML

UML: Ch. 1–2

Week 4 · 2/2

UML Class Diagrams

UML: Ch. 3

Week 4 · 2/4

UML Sequence, Use Case, and State Diagrams

UML: Ch. 4, 9, 10

Week 5 · 2/7

Additional UML Diagram Notation

UML: Ch. 5

Week 5 · 2/9

Additional UML Diagram Types

Week 5 · 2/11

Mid-semester break — no classes

Week 6 · 2/14

C++ Classes and Namespaces

C++: Ch. 1.5, 2.6, 7.1, 18.2

Week 6 · 2/16

C++ Access Control and Encapsulation

C++: Ch. 7.2, 7.3.4

Week 6 · 2/18

C++ Class Scope

C++: Ch. 7.4

Week 7 · 2/21

C++ Constructors

C++: Ch. 7.5

Week 7 · 2/23

C++ Static Members

C++: Ch. 7.6

Week 7 · 2/25

Midterm exam

C++: Ch. 1–7
UML: Ch. 1–5, 9–10

Week 8 · 2/28

Midterm exam postmortem

Week 8 · 3/2

C++ Copy Constructors, Copy-Assignment, and Destructors

C++: Ch. 13.1

Week 8 · 3/4

C++ Overloaded Operators

C++: Ch. 14.1

Week 9 · 3/7

C++ I/O, Arithmetic, and Relational Operators

C++: Ch. 14.2–14.3

Week 9 · 3/9

C++ Assignment, Subscript, and Increment/Decrement Operators

C++: Ch. 14.4–14.6

Week 9 · 3/11

C++ Function-Call and Conversion Operators

C++: Ch. 14.8–14.9

Week 10 · 3/14

C++ Object-Oriented Programming

C++: Ch. 15.1

Week 10 · 3/16

C++ Base and Derived Classes

C++: Ch. 15.2

Week 10 · 3/18

C++ Virtual Functions and Abstract Base Classes

C++: Ch. 15.3–15.4

Week 11 · 3/21–3/25

Spring break — no classes

Week 12 · 3/28

C++ Access Control and Inheritance

C++: Ch. 15.5

Week 12 · 3/30

C++ Class Scope and Inheritance

C++: Ch. 15.6

Week 12 · 4/1

C++ Copy Control and Inheritance

C++: Ch. 15.7

Week 13 · 4/4

C++ Library: I/O

C++: Ch. 8

Week 13 · 4/6

C++ Library: Containers and Algorithms

C++: Ch. 9–11

Week 13 · 4/8

C++ Library: Dynamic Memory

C++: Ch. 12

Week 14 · 4/11

C++ Templates

C++: Ch. 16.1

Week 14 · 4/13

C++ Template Arguments and Overloading

C++: Ch. 16.2–16.3

Week 14 · 4/15

C++ Variadic Templates and Specializations

C++: Ch. 16.4–16.5

Week 15 · 4/18

Introduction to Design Patterns

Week 15 · 4/20

Creational Patterns

Week 15 · 4/22

Structural and Behavioral Patterns

Week 16 · TBD

Final exam

C++: *
UML: *


This page was last modified on 2022-03-29 at 11:36:39.

Copyright © 2015–2022 George Fox University. All rights reserved.