Programarea Calculatoarelor (curs)
Dedicat studenților de anul I, semestrul I, cursul de programare a calculatoarelor are ca scop introducerea în domeniul programării și a științei calculatoarelor, precum și a proceselor și a instrumentelor de dezvoltare software.
Structura cursului și metodologia de evaluare
Cursul este structurat în 14 prelegeri de câte două ore și 14 ședințe de laborator, de câte două ore. Prezența în laborator este obligatorie.
Repartizarea punctelor
Punctajul maxim este de 100 de puncte, corespunzător notei 10. Acest punctaj este repartizat în felul următor:
- 40 de puncte - 4 teme de casă ce vor fi publicate în saptămânile 4, 6, 8 și 10;
- 40 de puncte - laborator;
- 20 de puncte - activitatea din timpul semestrului;
- 20 de puncte - colocviu de laborator;
- 20 de puncte - examen final;
- BONUS 10 puncte pentru activitate excepțională în timpul semestrului. Punctajul bonus este exclusiv la latitudinea titularului de curs.
Condiții de promovare
Condițiile minime de promovare sunt:
- cel mult trei absențe la laboratoare;
- minim 20 de puncte din punctajul de laborator;
- minim 10 puncte la examenul final;
- minim 50 puncte în total.
Curricula cursului
- Informații administrative; Prezentare instrumente utilizate (Moodle, Web-CAT, Virtualbox); Utilizarea resurselor online - Stackoverflow; Q&A - Fișier:Prezentare 1.pdf
- Ciclul de viață al unei aplicații (Software Development Life-Cycle - SDLC) - Arhitectură și Design; Caracteristicile limbajului C - diferențele față de C++; Standarde; Noțiuni elementare despre Compilator, limbaj și medii de dezvoltare; GCC și compilarea programului ”HelloWorld” - Fișier:Pc curs 1.pdf
- Bazele de numerație binară și hexazecimală; Stocarea unui număr negativ - convenția complement față de 2; Stocarea unui număr în virgulă mobilă - Standardul IEEE 754; Stocarea caracterelor - coduri ASCII și Unicode; Variabila; Operații pe biți - Fișier:Pc curs 2.pdf
- Tipuri de date - dimensiuni; Variabile globale și locale; Modificatori (short, long, const, signed, unsigned); Conversii (cast); Template-uri pentru citirea și scrierea datelor (printf & scanf); Operatori (artimetici, logici, relaționali, condiționali); Precedența operatorilor; Variabila și contextul curent - Fișier:Pc curs 3.pdf
- Blocuri condiționale (if, switch); Blocuri repetitive (for, while, do-while); Cuvintele cheie break și continue
- Vectori uni și multi-dimensionali; Operații cu șiruri de caractere
- Recapitulare și aplicații
- Funcții - definiție și apel; Funcții void; Cuvântul cheie return
- Funcții - exerciții și recursivitate
- Structuri (struct, union, enum)
- Structura memoriei (stack, heap & text); Modelul execuției unui program;
- Variabile de tip pointer - adrese în memorie; Pointeri și alocarea dinamică de memorie; Aritmetica pointerilor și conversii de pointeri
- Lucrul cu fișiere
- Q&A pentru examen
Curricula laboratorului
- Folosirea liniei de comandă în Linux; Compilarea programului HelloWorld; Sisteme de build: Makefile
- Sisteme de revision control: Git & Gitlab
- Utilizarea preprocesorului; Utilizarea stream-urilor standard ale unui proces (stdin, stdout, stderr)
- Exerciții cu variabile cu semn și în virgulă mobilă și operatori pe biți; Tipuri de date și conversii - citirea de la tastatură și afișarea pe stream-urile standard
- Exerciții folosind construcții condiționale
- Exerciții folosind blocuri repetitive
- Exerciții cu vectori
- Exerciții cu șiruri de caractere: căutare, concatenare, inserție, citire, scriere.
- Exerciții cu funcții; Compilarea unui executabil din mai multe fișiere sursă; Utilizarea fișierelor header
- Exerciții cu funcții recursive; Tool-uri de depanare: GDB
- Exerciții cu structuri pentru agregarea datelor
- Exerciții cu pointeri și alocare dinamică de memorie; Instrumente de evaluare a pierderilor de memorie - valgrind
- Exerciții cu scriere și citire din fișiere
- Colocviu de laborator
Materiale de studiu
Câte două probleme pe zi, până la Crăciun, ajutați-l pe Moșu`: http://adventofcode.com/
Programele de la curs
Programele scrise în cadrul cursului sunt disponibile pe repository-ul public de Git: https://gitlab.com/rhobincu/ProgramareaCalculatoarelor.git
Puteți rula comanda
git clone https://gitlab.com/rhobincu/ProgramareaCalculatoarelor.git
Coding Style
Aici găsiți lista de reguli pentru scrierea de aplicații în limbajul C.
Teme
Punctaje teme: aici
Înscriere Web-Cat
Pentru a putea accesa site-ul pentru submiterea temelor de programare, trebuie să urmați următorii pași:
- Intrați pe site-ul http://studenti.pub.ro
- Găsiți datele de acces pentru site-ul de cursuri (Moodle)
- Odată găsite, folosiți user-ul și parola pentru a vă autentifica pe site-ul de cursuri: http://electronica.curs.pub.ro/2015/
- După autentificarea pe site-ul de cursuri, folosiți același user și parolă pentru a vă autentifica pe WebCat. Atenție ca numele de utilizatori să nu conțină spații la început sau sfârșit.
- După autentificarea cu succes pe WebCat, completați-vă datele în tabelul următor: Înscriere utilizatori WebCat