PB161 C++ Programming

Faculty of Informatics
Autumn 2012
Extent and Intensity
2/2. 4 credit(s) (plus extra credits for completion). Recommended Type of Completion: zk (examination). Other types of completion: z (credit).
Teacher(s)
doc. RNDr. Petr Švenda, Ph.D. (lecturer)
Mgr. Martin Bezděka (seminar tutor)
Mgr. Tomáš Brukner (seminar tutor)
RNDr. Jiří Glozar (seminar tutor)
Mgr. Jan Juráň (seminar tutor)
Mgr. Vít Klouček (seminar tutor)
Mgr. Marek Klučár (seminar tutor)
Mgr. Petr Pilař (seminar tutor)
RNDr. Lukáš Ručka (seminar tutor)
RNDr. Ondřej Strnad, Ph.D. (seminar tutor)
RNDr. Šimon Tóth (seminar tutor)
RNDr. Marek Vinkler, Ph.D. (seminar tutor)
Mgr. Jiří Weiser (seminar tutor)
Bc. Jan Bilík (assistant)
RNDr. David Klaška (assistant)
Mgr. Michal Mikloš (assistant)
Mgr. Ing. Tomáš Svoboda (assistant)
RNDr. Vladimír Štill, Ph.D. (assistant)
Mgr. Jiří Zárevúcky (assistant)
Guaranteed by
prof. RNDr. Luděk Matyska, CSc.
Department of Computer Systems and Communications – Faculty of Informatics
Supplier department: Department of Computer Systems and Communications – Faculty of Informatics
Timetable
Mon 14:00–15:50 D1
  • Timetable of Seminar Groups:
PB161/T01A: Mon 12:00–13:55 Učebna S6 (20), J. Glozar, P. Švenda
PB161/T01AA: Wed 19. 9. to Fri 21. 12. Wed 9:00–10:55 Učebna S6 (20), J. Glozar, P. Švenda
PB161/01: Tue 8:00–9:50 B130, M. Klučár
PB161/02: Tue 18:00–19:50 B204, T. Brukner
PB161/03: Wed 12:00–13:50 B117, J. Juráň
PB161/04: Wed 12:00–13:50 B130, P. Pilař
PB161/05: Wed 18:00–19:50 B130, M. Bezděka
PB161/06: Thu 8:00–9:50 B116, M. Vinkler
PB161/07: Thu 10:00–11:50 B116, M. Vinkler
PB161/08: Thu 12:00–13:50 B116, M. Bezděka
PB161/09: Thu 12:00–13:50 B130, J. Juráň
PB161/10: Thu 14:00–15:50 B130, J. Juráň
PB161/11: Fri 8:00–9:50 B130, L. Ručka
PB161/12: Fri 10:00–11:50 B130, L. Ručka
PB161/13: Fri 12:00–13:50 B130, J. Weiser
PB161/14: Fri 12:00–13:50 B116
PB161/15: Tue 12:00–13:50 B116, P. Švenda
PB161/16: Mon 18:00–19:50 B311, J. Weiser
PB161/17: Mon 16:00–17:50 B130, Š. Tóth
Prerequisites
PB071 Introduction to the C language || SOUHLAS
Students are also required to have user experience with Unix OS, as homework is submitted and tested on a Unix server.
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
Course objectives
At the end of the course students should be able to:
Understand to principles of object oriented programming.
Design simple object oriented architectures and implement them.
Understand and use basic C++ syntax according to ANSI norm.
Use common C++ libraries, especially STL.
Annotate source code with respect to automatically generated documentation.
Use modern development tools (IDE, debugger, version control...).
Follow best practices guidelines for C++ programming.
Compile programs both under Unix and Windows.
Syllabus
  • Basic features of C++ (with respect to C). Standards, compilers.
  • Basic principles of object oriented programming (OOP). Object programming methodologies.
  • User defined data types. Classes in C++. Class components.
  • OOP in C++. Encapsulation, Inheritance, Polymorphism.
  • Dynamic memory allocation. Dynamic memory management. Automatic and class pointers.
  • Input and output in C++.
  • Exception handling. Defensive programming.
  • Templates. Standard C++ library and standard template library. Libraries for numeric computing.
  • Application of object oriented design and design patterns in C++.
  • Other OOP languages. Java and C# as compared to C++.
Literature
  • STROUSTRUP, Bjarne. The C++ programming language. 3rd ed. Reading: Addison-Wesley, 1997, x, 910 s. ISBN 0-201-88954-4. info
  • VIRIUS, Miroslav. Programování v C++. 1. vyd. Praha: ČVUT, 1998, 364 s. ISBN 8001018741. info
  • VIRIUS, Miroslav. Pasti a propasti jazyka C++ : podrobný průvodce pokročilého uživatele. 1. vyd. Praha: Grada, 1997, 251 s. ISBN 8071696072. info
  • VIRIUS, Miroslav. Od C k C++. 1. vyd. České Budějovice: KOPP, 2000, 227 s. ISBN 80-7232-110-2. info
  • LOUIS, Dirk, Petr MEJZLÍK and Miroslav VIRIUS. Jazyky C a C++ podle normy ANSI/ISO: kompletní kapesní průvodce. 1. vyd. Praha: Grada Publishing, 1999, 644 s. ISBN 80-7169-631-5. info
  • MEYERS, Scott. Effective C++ :50 specific ways to improve your programs and designs. 2nd ed. Reading: Addison-Wesley, 1998, xx, 256 s. ISBN 0-201-92488-9. info
Bookmarks
https://is.muni.cz/ln/tag/FI:PB161!
Teaching methods
Teaching consists from theoretical lectures combined with the practical exercises and programming homework selected to practice topics from lectures.
Assessment methods
In seminars, the students create programs requested (usually finishing it as individual work). The programs are rated in a point scale using previously given criteria. Preferably the course is ended by an examination made by a computer testing program. To be allowed to pass the test, the student must obtain the credit from the seminar and produce a final program. The classification depends on the quality of work in the seminar, quality of the final program and the result of the test.
If the student chose finishing the course with a seminar credit only, he has to finish the programs given throughout the term. No final program nor the test is required in that case.
Language of instruction
Czech
Further comments (probably available only in Czech)
Study Materials
The course is taught annually.
Listed among pre-requisites of other courses
Teacher's information
http://cecko.eu/public/pb161
The course is also listed under the following terms Autumn 2002, Autumn 2003, Autumn 2004, Autumn 2005, Autumn 2006, Autumn 2007, Autumn 2008, Autumn 2009, Autumn 2010, Autumn 2011, Autumn 2013, Autumn 2014, Autumn 2015, Autumn 2016, Autumn 2017, Autumn 2018, Autumn 2019, Spring 2020, Spring 2021, Spring 2022, Spring 2023, Spring 2024, Spring 2025.
  • Enrolment Statistics (Autumn 2012, recent)
  • Permalink: https://is.muni.cz/course/fi/autumn2012/PB161