Course syllabus for Object oriented programming

Course syllabus adopted 2020-02-11 by Head of Programme (or corresponding).

Overview

  • Swedish nameObjektorienterad programmering
  • CodeDAT043
  • Credits7.5 Credits
  • OwnerTKDAT
  • Education cycleFirst-cycle
  • Main field of studyComputer Science and Engineering, Software Engineering
  • DepartmentCOMPUTER SCIENCE AND ENGINEERING
  • GradingTH - Pass with distinction (5), Pass with credit (4), Pass (3), Fail

Course round 1

  • Teaching language Swedish
  • Application code 49129
  • Open for exchange studentsNo
  • Only students with the course round in the programme overview.

Credit distribution

0112 Examination 4.5 c
Grading: TH
4.5 c
  • 13 Mar 2021 am J
  • 10 Jun 2021 am J
  • 18 Aug 2021 am J
0212 Laboratory 3 c
Grading: UG
3 c

In programmes

Examiner

  • Joachim von Hacht
Go to coursepage (Opens in new tab)

Eligibility

General entry requirements for bachelor's level (first cycle)
Applicants enrolled in a programme at Chalmers where the course is included in the study programme are exempted from fulfilling the requirements above.

Specific entry requirements

The same as for the programme that owns the course.
Applicants enrolled in a programme at Chalmers where the course is included in the study programme are exempted from fulfilling the requirements above.

Course specific prerequisites

 

Aim

The aim of this course is to teach the fundamental principles of the object oriented approach to program development, and how to construct object oriented programs. Object oriented development methods are widely spread and take a strong position today.
Object oriented programs consist of a collection of cooperating objects. The objects encapsulate data together with methods for accessing and updating the data. Objects are described by data types called classes.

Learning outcomes (after completion of the course the student should be able to)

The student should be able to complete programming tasks on a fairly basic level. This means the student should be able to explain and use:

  • A modern development environment (editor, compiler, debugger)
  • Data as primitive variables and reference variables/objects.
  • Basic algorithms.
  • Functional decomposition and testing.
  • References: Be able to visualize reference semantics, variables, values, references, and objects.
  • Types: primitive and reference types (arrays, class, and interface types), implicit and explicit type conversions, enumeration types, wrapper types and boxing. Super and sub types.
  • Standard libraries for classes/objects and collections.
  • Own classes and implementations and interface inheritance.
  • Polymorphism
  • An object oriented model of some problem domain.

Content

The course uses the Java language. The following will be addressed:


  • In and output using streams
  • Literals, types, variables, declarations, initialization, operators, expressions and statements, casts, scope
  • Control statements: if, while, for, break, switch.
  • One and two dimensional arrays
  • Methods, parameters, return types, method calls, local variables, overloaded and overridden methods.
  • Primitive types vs reference types, value and reference semantics. Equality.
  • Classes, objects, interfaces, constructors and access. Inteface and implementation inheritance.
  • Graphical and event driven programs (JavaFX)
  • Exceptions and exception handling
  • Overview of file handling
  • Overview of generic classes and methods.
  • Texthandling, strings (String, StringBuilder, Character).
  • Java Collections
  • Instance and class variables/methods.

Organisation

Teaching is given in the form of computer exercises and labs and lectures. During exercises/labs you will be able to get help. 

Literature

Information about recommended course literature is communicated via the course web site before course start.

Examination including compulsory elements

A written exam and a number of compulsory programming assignments.