Ενότητες στην C Τεχνική Υλοποίησης Αφαιρετικών Τύπων Δεδομένων στην C

Σχετικά έγγραφα
ΑΦAΙΡΕΤΙΚΟΣ (ή ΑΦΗΡΗΜΕΝΟΣ) ΤΥΠΟΣ ΔΕΔΟΜΕΝΩΝ (ΑΤΔ) (Abstract Data Type-ADT) - σύνολο δεδομένων (data, objects) - σύνολο πράξεων στα δεδομένα

ΤΥΠΟΣ ΔΕΔΟΜΕΝΩΝ (ΑΤΔ) (Abstract Data Type-ADT)

ύο βασικές ιδέες Ενότητες Απόκρυψη Πληροφορίας, Αφηρηµένοι Τύποι εδοµένων 1) ιαχώρισε το πρόβληµα σεµικρότερα καλώς καθορισµένα υπο-προβλήµατα

Δομές Δεδομένων και Τεχνικές Προγραμματισμού Ενότητα 1: Εισαγωγικές Έννοιες

Βιβλιοθήκες Αφηρημένοι τύποι δεδομένων. Προγραμματισμός II 1

Ανάπτυξη Μεγάλων Εφαρµογών στη Γλώσσα C (2)

Μεταγλώττιση και σύνδεση πολλαπλών αρχείων κώδικα. Προγραμματισμός II 1

Προεπεξεργαστής C. Προγραμματισμός Ι 1

ΕΡΓΑΣΤΗΡΙΟ 6: Συναρτήσεις και Αναδρομή

ΟΝΤΟΚΕΝΤΡΙΚΟΣ ΠΡΟΓΡ/ΣΜΟΣ C++

Διάλεξη 22η: Επιπλέον στοιχεία της C

Προγραμματισμός Ι. Δυναμική Διαχείριση Μνήμης. Δημήτρης Μιχαήλ. Ακ. Έτος Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο

Η Γλώσσα Προγραµµατισµού C++ (The C++ Programming Language) Ιστοσελίδα του µαθήµατος. Περιεχόµενα. ηµήτριος Κατσαρός, Ph.D. Κλάσεις.

Βασικές Αρχές Προγραμματισμού

Αλγόριθμοι Ταξινόμησης Μέρος 1

Προγραμματισμό για ΗΜΥ

ΑΣΚΗΣΗ 1: TO ΠΕΡΙΒΑΛΛΟΝ ΕΡΓΑΣΙΑΣ DEV-C++

Δομημένος Προγραμματισμός (ΤΛ1006)

Ανάπτυξη και Σχεδίαση Λογισμικού

Κεφάλαιο : Εισαγωγή στην C: (Διαλέξεις 3-4)

Εξοικείωση με το πρόγραμμα DEV C++ Επικοινωνία Χρήστη - Υπολογιστή

Δομημένος Προγραμματισμός. Τμήμα Επιχειρηματικού Σχεδιασμού και Πληροφοριακών Συστημάτων

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΕΠΛ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΜΕΘΟΔΩΝ ΕΠΙΛΥΣΗΣ ΠΡΟΒΛΗΜΑΤΩΝ

Προγραμματισμός ΙΙ Εαρινό εξάμηνο Εργασία 3 Βιβλιοθήκη για λειτουργίες σε γράφους

Εισαγωγή στον Προγραμματισμό

Η γλώσσα προγραμματισμού C

(programming interfaceή/και application programming interface API).

Διαδικαστικός Προγραμματισμός

Κεφάλαιο 6: Συναρτήσεις IΙΙ Αρθρωτός Προγραμματισμός. (Διάλεξη 14) Παράδειγμα: Αλλαγή τιμής μεταβλητής μόνο τοπικά

B. Ενσωμάτωση Ιθαγενών Μεθόδων

Εισαγωγή στον Προγραμματισμό

2η Προγραµµατιστική Εργασία

Προγραμματισμός Η/Υ. Ενότητα 3: Top Down Σχεδιασμός

Κεφάλαιο 6: Συναρτήσεις IΙΙ Αρθρωτός Προγραμματισμός. Δείκτες (Διάλεξη 14)

Η βασική συνάρτηση προγράμματος main()

Προγραμματισμός Ι. Προεπεξεργαστής. Δημήτρης Μιχαήλ. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο

Ηβασικήσυνάρτηση προγράμματος main()

Προγραμματισμός Ι (ΗΥ120)

CE121 Προγραµµατισµός 2. Εισαγωγή σε Makefiles. CE121 -

CE121 Προγραµµατισµός 2. Εισαγωγή σε Makefiles. CE121 -

Προγραμματισμός Ι (ΗΥ120)

Η Γλώσσα Προγραµµατισµού C++ (The C++ Programming Language)

Περιεχόμενα. Πρόλογος... 17

ΕΙΣΑΓΩΓΗ ΣΤΟN ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΠΑΤΡΩΝ ΠΟΛΥΤΕΧΝΙΚΗ ΣΧΟΛΗ ΤΜΗΜΑ ΜΗΧΑΝΙΚΩΝ Η/Υ ΚΑΙ ΠΛΗΡΟΦΟΡΙΚΗΣ

Π. Σταθοπούλου ή Οµάδα Α (Φοιτητές µε µονό αριθµό Μητρώου ) ιδασκαλία : Παρασκευή 11πµ-13µµ ΗΛ7

Προγραμματισμός Υπολογιστών με C++

Προγραμματισμός Ι (ΗΥ120)

Κεφάλαιο : Εισαγωγή στην C. ( ιαλέξεις 3-4) ιδάσκων: ηµήτρης Ζεϊναλιπούρ

Αρχεία Κεφαλίδων ΑΡΧΕΙΑ ΚΕΦΑΛΙΔΩΝ. Γεώργιος Παπαϊωάννου ( )

Διαδικασία Ανάπτυξης Λογισμικού

Η γλώσσα προγραμματισμού C

Εισαγωγή στον Προγραµµατισµό. Πανεπιστήµιο Θεσσαλίας Τµήµα Ηλεκτρολόγων Μηχανικών και Μηχανικών Η/Υ

Δομημένος Προγραμματισμός

Εισαγωγή στον Προγραµµατισµό. Διάλεξη 2 η : Βασικές Έννοιες της γλώσσας προγραµµατισµού C Χειµερινό Εξάµηνο 2011

Το λειτουργικό σύστημα. Προγραμματισμός II 1

double sum(double a, double b) { return(a+b); } double my_avg(double a, double b) { return(sum(a, b)/2.0); }

Το λειτουργικό σύστημα. Προγραμματισμός II 1

#include <stdlib.h> Α. [-128,127] Β. [-127,128] Γ. [-128,128]

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Μέθοδοι

#define, 70, 575 #elif, 580 #else, 580 #endif, 580 #error, 584 #if, 580 #ifdef, 583 #ifndef, 580, 583 #include, 70, 227, 574 #undef, 579

Προγραμματισμός Υπολογιστών με C++

Προγραμματισμός Η/Υ 1 (Εργαστήριο)

Συναρτήσεις. Εισαγωγή

Εργαστήριο 1: Επανάληψη Βασικών Εννοιών στη Γλώσσα C

Κεφάλαιο , 3.2: Συναρτήσεις II. (Διάλεξη 12)

8. Μέθοδοι (Methods)

Μεθόδων Επίλυσης Προβλημάτων

Κεφάλαιο 3.1, : Συναρτήσεις I. (Διάλεξη 11)

Προεπεξεργαστής της C. C Preprocessor. Προγραμματισμός II 1

ΑΣΚΗΣΗ 2: ΔΟΜΗ ΠΡΟΓΡΑΜΜΑΤΟΣ C, ΧΕΙΡΙΣΜΟΣ ΜΕΤΑΒΛΗΤΩΝ ΚΑΙ ΣΥΝΑΡΤΗΣΕΙΣ ΕΙΣΟΔΟΥ ΚΑΙ ΕΞΟΔΟΥ

ΕΡΓΑΣΤΗΡΙΟ 1 ΕΙΣΑΓΩΓΗ ΣΤΗ C. Τµήµα Πληροφορικής και Τηλεπικοινωνιών

Εισαγωγή στη γλώσσα προγραμματισμού C++

Ανάπτυξη και Σχεδίαση Λογισμικού

Δομημένος Προγραμματισμός

ΑΡΧΕΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ

ΕΠΛ 034: Εισαγωγή στον Προγραμματισμό για ΗΜΥ

Προγραμματισμός Ι (ΗΥ120)

Διάλεξη 17: Έλεγχος Λογισμικού

Προγραμματισμός Η/Υ (ΤΛ2007 )

Διάλεξη 16: Σχεδίαση Λογισμικού

Βαθμός Σχόλια. lab5 PASS PASS PASS PASS PASS. Οριακά PASS - Καλή δουλειά

ΑΡΧΕΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ

Π. Σταθοπούλου ή Οµάδα Α (Φοιτητές µε µονό αριθµό Μητρώου ) ιδασκαλία : Παρασκευή 11πµ-13µµ ΗΛ7

Προγραμματισμός Η/Υ (ΤΛ2007 )

Αρχές Προγραμματισμού

Εισαγωγή στον Προγραµµατισµό. Διάλεξη 8 η : Συναρτήσεις Χειµερινό Εξάµηνο 2011

Προγραμματισμός Η/Υ (ΤΛ2007 )

ΕΠΛ232 Προγραμματιστικές Τεχνικές και Εργαλεία Οργάνωση Προγραμμάτων σε Πολλαπλά Αρχεία (Κεφάλαιο , KNK-2ED)

Εργαστήριο 4_1 Λεκτική Ανάλυση - Flex Διδάσκοντες: Δρ. Γεώργιος Δημητρίου Δρ. Άχμεντ Μάχντι

Η γλώσσα προγραμματισμού C

Στόχοι και αντικείμενο ενότητας. Πέρασμα Πίνακα σε Συνάρτηση (συν.) Πέρασμα Πίνακα σε Συνάρτηση. #8.. Ειδικά Θέματα Αλγορίθμων

Π. Σταθοπούλου ή Οµάδα Α (Φοιτητές µε µονό αριθµό Μητρώου ) ιδασκαλία : Παρασκευή 11πµ-13µµ ΗΛ7

Μεθόδων Επίλυσης Προβλημάτων

Ανάπτυξη Μεγάλων Εφαρµογών στη Γλώσσα C (Programming in the large)

Εισαγωγή στον Προγραμματισμό

Πίνακες. Οι πίνακες αποτελούν ένα σηµαντικό δοµηµένο τύπο δεδοµένων (structured data type) ή πιο απλά µία δοµή δεδοµένων (data structure).

Δείκτες (Pointers) Ένας δείκτης είναι μια μεταβλητή με τιμή μια διεύθυνση μνήμης. 9.8

Περιεχόμενα. Πρόλογος... 21

Εξοικ Εξ ε οικ ίωση ε με το το πρόγ ραμμα πρόγ DEV C++ Επικοι Επικ νωνία οι Χρήσ Χρήστη τη Υπολ Υπο ογισ λ τή

ΕΙΣΑΓΩΓΗ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ Ενδεικτικές Απαντήσεις Εξετάσεων Β' Περιόδου Θέµα 1. (α')

Transcript:

Ενότητες στην C Τεχνική Υλοποίησης Αφαιρετικών Τύπων Δεδομένων στην C Δυσκολία: Προγράμματα που λύνουν «πραγματικά προβλήματα» μπορεί να είναι μεγάλα (χιλιάδες ή εκατομμύρια γραμμές κώδικα). Κανείς δεν καταλαβαίνει ή θυμάται τόσο μεγάλα προγράμματα. Πρόβλημα: Πώς ξεπερνάμε τις δυσκολίες;

Δύο βασικές ιδέες 1. Διαχώρισε το πρόβλημα σε μικρότερα καλώς καθορισμένα υπο-προβλήματα 2. Απόκρυψε πληροφορίες υλοποίησης, όπου είναι δυνατόν Τι σημαίνουν;

Διαχωρισμός (ΤΙ κάνει το κάθε τμήμα) Η πρώτη ιδέα απαιτεί να μπορούμε να κολλήσουμε τα κομμάτια στα οποία έχουμε χωρίσει το μεγάλο πρόβλημα. Τα μικρότερα κομμάτια πρέπει να «μπουν μαζί» για να κατασκευάσουμε μεγαλύτερα κομμάτια ή και το τελικό πρόγραμμα. Απόκρυψη υλοποίησης (ΠΩΣ το κάνει) Η δεύτερη ιδέα μας επιτρέπει να ανακάμψουμε από μια ενδεχομένως κακή απόφαση υλοποίησης χωρίς να χρειάζεται να ξεκινήσουμε από την αρχή. Από την άλλη πλευρά μια καλή υλοποίηση μπορεί να ξαναχρησιμοποιηθεί σε άλλα προγράμματα μειώνοντας τον χρόνο και το κόστος.

Ο μηχανισμός της C για να υλοποιήσουμε τις δύο πολιτικές είναι η Ενότητα (MODULE) Σε φυσικό επίπεδο αποτελείται από δύο αρχεία: Αρχείο Διεπαφής (InterfaceFile.h) Αρχείο Υλοποίησης (ImplementationFile.c) Το αρχείο Διεπαφής διαθέτει την Δημόσια (PUBLIC) πληροφορία, δηλαδή την πληροφορία που χρειάζεται ο Χρήστης για να χρησιμοποιήσει την λειτουργικότητα. Το αρχείο Υλοποίησης περιλαμβάνει την ιδιωτική πληροφορία, δηλαδή την υλοποίηση της λειτουργικότητας την οποία «δημοσιεύει» το αρχείο Διεπαφής.

Οργάνωση Προγράμματος σε Ενότητες (Πολλαπλά αρχεία) Interface Δημόσια Πληροφορία Header File υλοποιεί χρησιμοποιεί Πρόγραμμα Χρήστη ή Άλλη Ενότητα (Client/Driver) Implementation Ιδιωτική Πληροφορία Code File

Τι Είναι μια Ενότητα (Module) Ένα σύνολο δηλώσεων που μπορούν να χρησιμοποιηθούν σε ένα πρόγραμμα. Είναι μια μονάδα οργάνωσης ενός λογισμικού συστήματατος που A) Έχει αυτοτέλεια. Tοποθετούνται μαζί μια συλλογή από οντότητες (δεδομένα και πράξεις-συναρτήσεις) που ορίζουν ένα σύνολο δυνατοτήτων χρήσιμο στο να λύνει κάποια προβλήματα. (encapsulation ενθυλάκωση) B) Διαχωρίζει το Τι από το Πώς. Προσδιορίζει τι δεδομένα ή πράξεις επιτρέπεται να βλέπουν και να χρησιμοποιούν οι εξωτερικοί χρήστες.

Πώς δημιουργούμε μια ενότητα Διεπαφή Module.h Ένα αρχείο που περιλαμβάνει όλες τις οντότητες που πρέπει να είναι ορατές: constants, type definitions, variable definitions, and functions (i.e., function prototypes) που ο χρήστης επιτρέπεται να χρησιμοποιήσει (συνάρτηση) ή αλλάξει (μεταβλητή). Υλοποίηση Module.c Ένα αρχείο που περιλαμβάνει όλες τις ιδιωτικές οντότητες: τον κώδικα υλοποίησης των συναρτήσεων και όλες τις σταθερές, μεταβλητές και συναρτήσεις που ο χρήστης της ενότητας δεν επιτρέπεται να έχει άμεση πρόσβαση.

Module.h Module.c Δημόσια Πρόσβαση client.c #include "Module.h" User program #include "Module.h Υλοποίηση Ιδιωτικές Μεταβλητές

#ifndef CH2_BOOLEAN #define CH2_BOOLEAN Παράδειγμα Boolean Interface file: Boolean.h typedef enum BOOLEAN {F=0, T BOOLEAN; void kataxorisi (BOOLEAN * const bptr, BOOLEAN bexpr); BOOLEAN OR (BOOLEAN b1, BOOLEAN b2); BOOLEAN AND (BOOLEAN b1, BOOLEAN b2); BOOLEAN NOT (BOOLEAN b); int diabasma (BOOLEAN *bptr); void grapsimo (BOOLEAN b); #endif

Implementation file: Boolean.c #include <stdio.h> #include "Boolean.h" void kataxorisi (BOOLEAN * const bptr, BOOLEAN bexpr) { *bptr=bexpr; BOOLEAN OR (BOOLEAN b1, BOOLEAN b2) { if ((b1==t) (b2==t)) return T; else return F; BOOLEAN AND (BOOLEAN b1, BOOLEAN b2) { if ((b1==t) && (b2==t)) return T; else return F; BOOLEAN NOT (BOOLEAN b) { if ((b==t)) return F; else return T;

Πώς χρησιμοποιούμε μια ενότητα (Module): Το πρόγραμμα πελάτης (client) του Χρήστη κάνει δήλωση χρήσης μέσω include directive. #include <stdio.h> /* include system file */ /*. Other system inclusions. */ #include Module.h /* include non-system module */ /*. Other modules. */ /*. User Program. */

Παράδειγμα Χρήσης Boolean #include <stdio.h> #include <stdlib.h> #include "Boolean.h" int main( ) { BOOLEAN a=t, b=f, c; // μεταβλητές και αρχικοποίηση kataxorish(&c, OR(a,b)); kataxorish(&c, AND(a,b); a=f; kataxorisi(&a, T); kataxorisi(&c, AND ( OR(a, NOT(b)), OR (NOT(a), b));

Πλεονεκτήματα Ξεχωριστή μεταγλώττιση Ενότητας και Προγράμματος Χρήσης (όχι άμεσα ορατό με την χρήση Dev C++ ή VisualStudio) gcc.exe -c Boolean.c -o ch2_boolean.o gcc.exe -c main.c -o main.o gcc.exe Boolean.o main.o -o "Project1.exe"

Κοινό χαρακτηριστικό των ενοτήτων σε όλες τις γλώσσες που υποστηρίζουν αυτό τον μηχανισμό είναι η ξεχωριστή μεταγλώττιση (Separate Compilation) Απλά σημαίνει ότι η συλλογή δεδομένων και συναρτήσεων μπορεί να μεταγλωττιστεί αυτόνομα από άλλες και από άλλα προγράμματα που την χρησιμοποιούν. Αλλαγές στο πρόγραμμα του χρήστη ή σε μια από τις συλλογές απαιτεί την μεταγλώττιση ενός μικρού αριθμού ενοτήτων. Αυτό μπορεί να μην είναι σημαντικό για προγράμματα των Χ100 ή Χ1000 γραμμών, αλλά είναι κρίσιμο για προγράμματα Χ1.000.000

Αφαίρεση (Abstraction): Αφαίρεση Διαδικασιών (Procedural Abstraction) Πώς να αντικαταστήσουμε μια (μεγάλη) ακολουθία εντολών (πώς το κάνει) με ένα Όνομα και μια διεπαφή (τί κάνει). Ενσωματώνεται στις Συναρτήσεις (FUNCTION) με καλά καθορισμένες παραμέτρους και τύπο επιστροφής (return) Απόκρυψη Πληροφορίας (τοπικές μεταβλητές)

Αλλαγή Υλοποίησης (Αλλαγές μόνο στο boolean.c) #include <stdio.h> #include "Boolean.h" void kataxorisi (BOOLEAN * const bptr, BOOLEAN bexpr) { *bptr=bexpr; BOOLEAN OR (BOOLEAN b1, BOOLEAN b2) { return (b1 b2); /* πριν if ((b1==t) (b2==t)) return T; else return F; */ BOOLEAN AND (BOOLEAN b1, BOOLEAN b2) { return (b1&&b2); BOOLEAN NOT (BOOLEAN b) { return (!b);