PB162 Java
Faculty of InformaticsAutumn 2018
- Extent and Intensity
- 2/2/0. 4 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. Jakub Čecháček (seminar tutor)
RNDr. Karolina Dočkalová Burská, Ph.D. (seminar tutor)
Ing. Pavel Hrdina (seminar tutor)
Mgr. Jaroslav Kašpar (seminar tutor)
Mgr. Josef Ludvíček (seminar tutor)
Mgr. Patrik Majerčík (seminar tutor)
RNDr. Jaromír Plhák, Ph.D. (seminar tutor)
Mgr. Matúš Raček (seminar tutor)
Mgr. Marek Šabo (seminar tutor)
Bc. Karel Vaculík (seminar tutor)
Mgr. Jiří Weiser (seminar tutor)
RNDr. Aleš Zlámal (seminar tutor) - Guaranteed by
- doc. RNDr. Eva Hladká, Ph.D.
Department of Computer Systems and Communications – Faculty of Informatics
Supplier department: Department of Computer Systems and Communications – Faculty of Informatics - Timetable
- Tue 10:00–11:50 D3, Thu 8:00–9:50 D1
- Timetable of Seminar Groups:
PB162/02: Fri 10:00–11:50 B116, P. Hrdina
PB162/03: Thu 14:00–15:50 B117, A. Zlámal
PB162/04: Tue 10:00–11:50 B117, A. Zlámal
PB162/05: Mon 17. 9. to Mon 10. 12. Mon 10:00–11:50 A219, A. Zlámal
PB162/06: Fri 10:00–11:50 A219, A. Zlámal
PB162/07: Wed 12:00–13:50 A219, L. Bártek
PB162/08: Thu 10:00–11:50 A219, L. Bártek
PB162/09: Thu 8:00–9:50 A219, L. Bártek
PB162/10: Mon 17. 9. to Mon 10. 12. Mon 12:00–13:50 A219, L. Bártek
PB162/11: Tue 10:00–11:50 B116, J. Kašpar
PB162/12: Tue 8:00–9:50 B117, J. Čecháček
PB162/13: Wed 8:00–9:50 B117, J. Ludvíček
PB162/14: Mon 17. 9. to Mon 10. 12. Mon 12:00–13:50 B311, J. Plhák
PB162/15: Thu 10:00–11:50 B311, J. Plhák
PB162/16: Fri 8:00–9:50 A215, P. Hrdina
PB162/17: Mon 17. 9. to Mon 10. 12. Mon 18:00–19:50 B117, P. Majerčík
PB162/18: Mon 17. 9. to Mon 10. 12. Mon 16:00–17:50 B117, P. Majerčík
PB162/19: Thu 14:00–15:50 B116, K. Dočkalová Burská
PB162/20: Wed 18:00–19:50 B311, K. Vaculík
PB162/21: Mon 17. 9. to Mon 10. 12. Mon 18:00–19:50 A219, K. Vaculík
PB162/22: Thu 18:00–19:50 B116, M. Raček
PB162/23: Thu 8:00–9:50 B116, J. Kašpar
PB162/24: Thu 16:00–17:50 B116, M. Raček
PB162/25: Thu 18:00–19:50 A219, J. Weiser
PB162/26: Thu 16:00–17:50 B311, R. Ošlejšek - 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
- Applied Informatics (programme FI, B-AP)
- Bioinformatics (programme FI, B-AP)
- Informatics with another discipline (programme FI, B-EB)
- Informatics with another discipline (programme FI, B-FY)
- Informatics with another discipline (programme FI, B-GE)
- Informatics with another discipline (programme FI, B-GK)
- Informatics with another discipline (programme FI, B-CH)
- Informatics with another discipline (programme FI, B-IO)
- Informatics with another discipline (programme FI, B-MA)
- Informatics with another discipline (programme FI, B-TV)
- Public Administration Informatics (programme FI, B-AP)
- Mathematical Informatics (programme FI, B-IN)
- Mathematics with Informatics (programme PřF, N-MA)
- Mathematics (programme PřF, B-MA)
- Parallel and Distributed Systems (programme FI, B-IN)
- Computer Graphics and Image Processing (programme FI, B-IN)
- Computer Networks and Communication (programme FI, B-IN)
- Computer Systems and Data Processing (programme FI, B-IN)
- Business Informatics (programme ESF, B-SI)
- Programmable Technical Structures (programme FI, B-IN)
- Embedded Systems (programme FI, N-IN)
- Service Science, Management and Engineering (programme FI, N-AP)
- Social Informatics (programme FI, B-AP)
- Artificial Intelligence and Natural Language Processing (programme FI, B-IN)
- 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 (Autumn 2018, recent)
- Permalink: https://is.muni.cz/course/fi/autumn2018/PB162