Primele programe C
In aceasta sectiune sint prezentate si explicate patru programe cu scopul de a asigura un suport de baza pentru prezentarile din capitolele urmatoare.
Prin traditie primul program C este un mic exemplu din lucrarea devenita clasica – „The C programming language”, de Brian W Kernigham si Dennis M Ritchie.
#include <stdio.h>
main()
Acest program afiseaza un mesaj de salut. 343b15d
Prima linie indica faptul ca se folosesc functii de intrare / iesire, si descrierea modului de utilizare (numele, tipul argumentelor, tipul valorii returnate etc) a acestora se afla in fisierul cu numele stdio.h
A doua linie declara functia main care va contine instructiunile programului. In acest caz singura instructiune este un apel al functiei printf care afiseaza un mesaj la terminal. Mesajul este dat intre ghilimele si se termina cu un caracter special new-line ('n'
Instructiunea return preda controlul sistemului de operare la terminarea programului si comunica acestuia codul 0 pentru terminare. Prin conventie aceasta valoare semnifica terminarea normala a programului - adica nu au aparut erori in prelucrarea datelor.
Corpul functiei main apare intre acolade.
Al doilea program asteapta de la terminal introducerea unor numere intregi nenule si determina suma lor. In momentul in care se introduce o valoare zero, programul afiseaza suma calculata.
#include <stdio.h>
main() while (n!=0);
printf('%dn',s);
return 0;
}
In cadrul functiei main se declara doua variabile s si n care vor memora valori intregi. Variabila s (care va pastra suma numerelor introduse) este initializata cu valoarea
In continuare se repeta o secventa de doua instructiuni, prima fiind o operatie de intrare si a doua o adunare.
Primul argument al functiei scanf - formatul de introducere '%d' - indica faptul ca se asteapta introducerea unei valori intregi in format zecimal de la terminal (consola). Al doilea argument indica unde se va depune in memorie valoarea citita; de aceea este necesar sa se precizeze adresa variabilei n (cu ajutorul operatorului &
In a doua instructiune la valoarea variabilei s se aduna valoarea variabilei n. Operatorul are semnificatia aduna la.
Aceasta secventa se repeta (do) cit timp (while) valoarea introdusa (n) este nenula. Operatorul are semnificatia diferit de.
In final functia printf afiseaza pe terminal valoarea variabilei s in format zecimal.
Al treilea program asteapta de la terminal introducerea unei valori naturale n, dupa care mai asteapta introducerea a n valori reale (dubla precizie): a0 a1 an . In continuare se parcurge aceasta lista si se determina produsul valorilor strict pozitive. In final programul afiseaza produsul calculat.
#include <stdio.h>
main()
In cadrul functiei main se declara doua variabile n si i care vor memora valori intregi. Variabila n pastreaza numarul de valori reale din lista a. Se declara de asemenea un tablou unidimensional a care va memora 100 de valori de tip real (dubla precizie), si o variabila p care va memora produsul cerut.
Se citeste de la terminal o valoare n. In continuare se introduc valorile reale ai i n ). Formatul de introducere '%lf' indica faptul ca se asteapta introducerea unei valori reale de la terminal, care va fi depusa la locatia de memorie asociata variabilei ai. In locul constructiei &a[i] se poate folosi forma echivalenta a+i
Pentru a introduce toate valorile ai se efectueaza un ciclu for, in cadrul caruia variabila i (care controleaza ciclul) ia toate valorile intre (inclusiv) si n (exclusiv) cu pasul . Trecerea la urmatoarea valoare a variabilei i se face cu ajutorul operatorului
In continuare variabila p, care va memora produsul valorilor cerute, se initializeaza cu . Fiecare valoare ai este verificata (instructiunea if) daca este strict pozitiva si in caz afirmativ este inmultita cu valoarea p. Operatorul are semnificatia inmulteste cu.
Al patrulea program este o ilustrare a unor probleme legate de capacitatea reprezentarilor valorilor de tip intreg si virgula mobila.
#include <stdio.h>
int main()
Variabila k, care ar trebui sa memoreze valoarea 57600, are tipul intreg scurt (short), pentru care domeniul de valori este restrins la –32768 32767. Astfel ca valoarea 1110000100000000(2) (in zecimal 57600), in reprezentare intreaga cu semn este de fapt –7936.
Al doilea set de operatii necesita o analiza mai atenta; explicatiile sint valabile pentru programe care ruleaza pe arhitecturi Intel. Variabila c, care ar trebui sa memoreze valoarea 2461357 (rezultatul corect), va avea valoarea 2461356, deoarece tipul float are rezervate pentru mantisa doar 24 de cifre binare. Rezultatul este foarte apropiat de cel corect deoarece rezultatele intermediare se pastreaza in registrii coprocesorului matematic cu precizie maxima. Abia la memorare se efectueaza trunchierea, de unde rezulta valoarea afisata.
Cu totul altfel stau lucrurile in cazul celui de al treilea set de operatii. Aici rezultatele intermediare sint memorate de fiecare data cu trunchiere in variabile de tip float. In final se calculeaza si diferenta dintre cele doua valori trunchiate, de unde rezulta valoarea 16777216.
Inainte de terminare se verifica daca valorile c si w sint egale. In caz afirmativ se comunica sistemului de operare un cod 0 (terminare normala). In caz contrar se comunica un cod 1 (terminare anormala).
Rulati acest program pe diferite sisteme de calcul si observati care este rezultatul.
|