PB162 Java
Faculty of InformaticsSpring 2020
- Extent and Intensity
- 2/2/0. 3 credit(s) (plus extra credits for completion). Recommended Type of Completion: zk (examination). Other types of completion: z (credit).
- Teacher(s)
- prof. RNDr. Tomáš Pitner, Ph.D. (lecturer)
doc. RNDr. Radek Ošlejšek, Ph.D. (lecturer)
Mgr. Luděk Bártek, Ph.D. (seminar tutor)
Mgr. Dávid Brilla (seminar tutor)
Ing. Lukáš Grolig (seminar tutor)
Mgr. Boris Jaduš (seminar tutor)
Mgr. Dominik Pilár (seminar tutor)
Mgr. Matúš Raček (seminar tutor)
RNDr. Vladimír Ulman, Ph.D. (seminar tutor)
RNDr. Aleš Zlámal (seminar tutor)
Mgr. Jakub Čecháček (assistant)
Mgr. Miroslav Lučkai (assistant) - Guaranteed by
- prof. RNDr. Tomáš Pitner, Ph.D.
Department of Computer Systems and Communications – Faculty of Informatics
Supplier department: Department of Computer Systems and Communications – Faculty of Informatics - Timetable
- Mon 17. 2. to Fri 15. 5. Wed 12:00–13:50 D1
- Timetable of Seminar Groups:
PB162/02: Mon 17. 2. to Fri 15. 5. Fri 10:00–11:50 B116, R. Ošlejšek
PB162/03: Mon 17. 2. to Fri 15. 5. Thu 12:00–13:50 B116, L. Bártek
PB162/04: Mon 17. 2. to Fri 15. 5. Mon 12:00–13:50 B116, L. Bártek
PB162/05: Mon 17. 2. to Fri 15. 5. Tue 10:00–11:50 B116, A. Zlámal
PB162/06: Mon 17. 2. to Fri 15. 5. Wed 14:00–15:50 B116, A. Zlámal
PB162/07: Mon 17. 2. to Fri 15. 5. Fri 12:00–13:50 A215, R. Ošlejšek
PB162/08: Mon 17. 2. to Fri 15. 5. Fri 14:00–15:50 B117, V. Ulman
PB162/09: Mon 17. 2. to Fri 15. 5. Mon 14:00–15:50 B117, M. Raček
PB162/10: Mon 17. 2. to Fri 15. 5. Tue 18:00–19:50 B116, L. Grolig
PB162/11: Mon 17. 2. to Fri 15. 5. Tue 16:00–17:50 B116, D. Pilár
PB162/12: Mon 17. 2. to Fri 15. 5. Mon 16:00–17:50 B117, D. Brilla - Prerequisites
- Command of a procedural programming language (Python, C) in the extent of the IB001 Introduction to Programming using C, IB111 Foundations of Programming, or IB113 Introduction to Programming and Algorithms.
- Course Enrolment Limitations
- The course is also offered to the students of the fields other than those the course is directly associated with.
- fields of study / plans the course is directly associated with
- there are 64 fields of study the course is directly associated with, display
- Course objectives
- During this course, students:
gain the basic knowledge of object oriented programming in Java;
become familiar with the basic Java and OO terminology, as well as necessary language syntax and semantics rules;
be able to analyze, design and implement simple software solutions with the appropriate tools. - Learning outcomes
- At the end of the course students should be able to:
explain and use principles of object paradigm;
use basic principles of object-oriented design for coding;
create programs on Java SE platform;
use development tools efficiently, e.g. IDE, unit tests, git, etc.; - Syllabus
- Introduction to Java - principles, history. Java development lifecycle, basic development tools.
- Basic concepts and terminology of object-oriented programming - class, instance (object), variable, method. Encapsulation.
- Cooperation and communication among objects.
- Interfaces, specification, implementation.
- Basic programmer's conventions - coding style, naming, documentary comment, API documentation.
- Unit testing with junit.
- Inheritance, polymorphism. Class hierarchy. Architecture of Java programs - methods, classes, packages.
- Abstract classes. Access modifiers.
- Basic program constructs. Primitive datatypes, object types and arrays.
- Exceptions. Built-in exceptions, design of custom exceptions.
- Java containers.
- Java I/O.
- Basic design patterns.
- Literature
- PITNER, Tomáš. Java - začínáme programovat : podrobný průvodce začínajícího uživatele. Praha: Grada, 2002, 222 s. ISBN 8024702959. info
- ECKEL, Bruce. Myslíme v jazyku Java : knihovna programátora. Praha: Grada, 2001, 431 s. ISBN 8024790106. info
- Učebnice jazyka JAVA. Edited by Pavel Herout. 1. vyd. České Budějovice: KOPP, 2001, 349 s. ISBN 80-7232-115-3. info
- ECKEL, Bruce. Myslíme v jazyku Java : knihovna zkušeného programátora. Praha: Grada, 2000, 470 s. ISBN 8024700271. info
- Teaching methods
- Lectures with many examples, project-oriented lab sessions, homeworks.
- Assessment methods
- In the course of the semester, the students will work on project, gaining points. The algorithmic optimality together with coding style and documentation will be taken into evaluation. Another points can be obtained on practical lessons in the form of short online tests. Another points can be obtained from in-term test, as well as from the final exam. Both in-term tests and final exam has the form of practical programming, final exam is more complex. 70 out of the total 100 points is required to complete the course successfully.
- Language of instruction
- Czech
- Follow-Up Courses
- Further Comments
- Study Materials
The course is taught annually. - Listed among pre-requisites of other courses
- IB113 Introduction to Programming and Algorithms
!NOW(IB111) && !IB111 && !PB162 && !PB161 && !PB071 && !IB001 && !program(B-INF) && !program(B-PVA) && !program(B-CS) - PB007 Software Engineering I
PB160 || PB161 || PB162 || PB174 || PV178 || PB112 - PB112 Foundations of Object Oriented Programming in Java
!(PB162) && ! NOW(PB162) - PV168 Seminar in Java programming
PB162 || SOUHLAS - PV255 Game Development I
PB009 && PV112 && (PB161 || PB162 || PV178) - PV256 Introduction to Development for Android
PB162 || PB112 - PV292 Multiplatform Flutter Application Development
PB162 || PV168 || PA165 || PV178 || PV256 || PB138 || SOUHLAS
- IB113 Introduction to Programming and Algorithms
- Teacher's information
- http://www.fi.muni.cz/~tomp/pb162/slides/index.html
- Enrolment Statistics (Spring 2020, recent)
- Permalink: https://is.muni.cz/course/fi/spring2020/PB162