Σύνταξη & Συντακτική Ανάλυση
|
|
- Ἄρτεμις Θεοδοσίου
- 8 χρόνια πριν
- Προβολές:
Transcript
1 Σύνταξη & Συντακτική Ανάλυση Μια γραµµατική για τα Αγγλικά Μια πρόταση αποτελείται από µια ουσιαστική φράση, ένα ρήµα, και µια ουσιαστική φράση <S> ::= <NP> <V> <NP> Rene Mgritte, Le Seize Septemre Μια ουσιαστική φράση αποτελείται από ένα άρθρο και ένα ουσιαστικό Ρήµατα είναι τα εξής Άρθρα είναι τα εξής Ουσιαστικά είναι τα εξής... <NP> ::= <A> <N> <V> ::= loves htes ets <A> ::= the <N> ::= dog t rt Κωστής Σαγώνας <kostis@s.ntu.gr> Σύνταξη και Συντακτική Ανάλυση 2 Πως δουλεύει µια γραµµατική Μια γραµµατική είναι ένα σύνολο κανόνων που ορίζουν το πως κατασκευάζεται ένα συντακτικό δένδρο Ξεκινάµε βάζοντας το <S> στη ρίζα του δένδρου Οι κανόνες της γραµµατικής λένε πως µπορούµε να προσθέσουµε παιδιά σε κάθε σηµείο του δένδρου Για παράδειγµα, ο κανόνας <S> ::= <NP> <V> <NP> λέει ότι µπορούµε να προσθέσουµε κόµβους <NP>, <V>, και <NP>, µε αυτή τη σειρά, ως παιδιά του κόµβου <S> Γραµµατική για αριθµητικές εκφράσεις <expr> ::= <expr> + <expr> <expr> * <expr> ( <expr> ) Μια αριθµητική έκφραση µπορεί να είναι το άθροισµα δύο άλλων εκφράσεων, ή το γινόµενο δύο εκφράσεων, ή µια έκφραση που περικλείεται από παρενθέσεις, ή κάποια από τις µεταβλητές,, ή Σύνταξη και Συντακτική Ανάλυση 3 Σύνταξη και Συντακτική Ανάλυση 4 Συντακτικό δένδρο Συστατικά µιας γραµµατικής <expr> ( <expr> ) <expr> * <expr> ( <expr> ) <expr> + <expr> αρχικό σύµβολο κανόνας παραγωγής µη τερµατικά σύµβολα <S> ::= <NP> <V> <NP> <NP> ::= <A> <N> <V> ::= loves htes ets <A> ::= the <N> ::= dog t rt Σύνταξη και Συντακτική Ανάλυση 5 τερµατικά σύµβολα (λεκτικές µονάδες) Σύνταξη και Συντακτική Ανάλυση 6
2 Ορισµός γραµµατικών σε µορφή Bkus-Nur Μια γραµµατική σε µορφή Bkus-Nur αποτελείται από Ένα σύνολο από λεκτικές µονάδες (tokens tokens) Συµβολοσειρές που αποτελούν τα µικρότερα αδιαίρετα κοµµάτια της σύνταξης του προγράµµατος Ένα σύνολο από µη τερµατικά σύµβολα (non non-terminls terminls) Συµβολοσειρές που εγκλείονται σε αγκύλες, π.χ. <NP>, και αντιπροσωπεύουν κοµµάτια του συντακτικού της γλώσσας ε συναντιούνται στο πρόγραµµα, αλλά είναι σύµβολα που βρίσκονται στο αριστερό µέρος κάποιων κανόνων της γραµµατικής Το αρχικό σύµβολο (strt symol) της γραµµατικής Ένα συγκεκριµένο µη τερµατικό σύµβολο που αποτελεί τη ρίζα του συντακτικού δένδρου για κάθε αποδεκτό από τη γλώσσα πρόγραµµα Ένα σύνολο από κανόνες παραγωγής (prodution rules) Κανόνες παραγωγής Οι κανόνες παραγωγής χρησιµοποιούνται για την κατασκευή του συντακτικού δένδρου Κάθε κανόνας έχει τη µορφή Α ::= Το αριστερό µέρος Α αποτελείται από ένα µη τερµατικό σύµβολο Το δεξί µέρος είναι µια ακολουθία από τερµατικά (λεκτικές µονάδες) και µη τερµατικά σύµβολα Κάθε κανόνας προσδιορίζει έναν πιθανό τρόπο κατασκευής του συντακτικού υποδένδρου που έχει ως ρίζα του το µη τερµατικό σύµβολο στο αριστερό µέρος Α του κανόνα και ως παιδιά αυτής της ρίζας (µε την ίδια σειρά εµφάνισης) έχει τα σύµβολα στο δεξί µέρος του κανόνα Σύνταξη και Συντακτική Ανάλυση 7 Σύνταξη και Συντακτική Ανάλυση 8 Επιλογές στη γραφή των κανόνων παραγωγής Όταν υπάρχουν περισσότεροι από ένας κανόνες παραγωγής µε το ίδιο αριστερό µέρος, µπορούµε να κάνουµε χρήση της παρακάτω συντοµογραφίας Στη BNF γραµµατική µπορούµε να δώσουµε το αριστερό µέρος, το διαχωριστή ::=, και µετά µια ακολουθία από δεξιά µέρη που διαχωρίζονται από το ειδικό σύµβολο Οι δύο γραµµατικές είναι ίδιες <expr> ::= <expr> + <expr> <expr> * <expr> ( <expr> ) <expr> ::= <expr> + <expr> <expr> ::= <expr> * <expr> <expr> ::= ( <expr> ) <expr> ::= <expr> ::= <expr> ::= Σύνταξη και Συντακτική Ανάλυση 9 Κανόνες παραγωγής του κενού Το ειδικό µη τερµατικό <empty> χρησιµοποιείται σε περιπτώσεις που θέλουµε κάποιος κανόνας να µην παράγει τίποτα Για παράδειγµα, οι παρακάτω κανόνες ορίζουν τη δοµή if-then των περισσοτέρων γλωσσών, η οποία επιτρέπει την ύπαρξη ενός προαιρετικού else <if-stmt> ::= if <expr> then <stmt> <else-prt> <else-prt> ::= else <stmt> <empty> Σύνταξη και Συντακτική Ανάλυση 10 Κατασκευή συντακτικών δένδρων Αρχίζουµε την κατασκευή βάζοντας το αρχικό σύµβολο της γραµµατικής στη ρίζα του δένδρου Προσθέτουµε παιδιά σε κάθε µη τερµατικό σύµβολο, χρησιµοποιώντας κάποιον από τους κανόνες παραγωγής της γλώσσας για το συγκεκριµένο µη τερµατικό Η διαδικασία τερµατίζει όταν όλα τα φύλλα του δένδρου αποτελούνται από λεκτικές µονάδες Η συµβολοσειρά που αντιστοιχεί στο δένδρο βρίσκεται διαβάζοντας τα φύλλα του δένδρου από αριστερά προς τα δεξιά Σύνταξη και Συντακτική Ανάλυση 11 Παραδείγµατα Τα συντακτικά δένδρα για τις παρακάτω εκφράσεις + (+) (+()) *+ Η κατασκευή των συντακτικών δένδρων είναι η δουλειά του συντακτικού αναλυτή ενός µεταγλωττιστή Υπάρχουν διάφοροι αποδοτικοί αλγόριθµοι και εργαλεία για ηµιαυτόµατη κατασκευή του συντακτικού αναλυτή Σύνταξη και Συντακτική Ανάλυση 12
3 Τυπικός ορισµός σύνταξης γλωσσών Για να ορίσουµε τη σύνταξη των γλωσσών προγραµµατισµού χρησιµοποιούµε γραµµατικές Η γλώσσα που ορίζεται από µια γραµµατική είναι το σύνολο των συµβολοσειρών για τα οποία η γραµµατική µπορεί να παράξει συντακτικά δένδρα Τις περισσότερες φορές το σύνολο αυτό είναι άπειρο (παρόλο που η γραµµατική είναι πεπερασµένη) Η κατασκευή µιας γραµµατικής για µια γλώσσα µοιάζει λίγο µε προγραµµατισµό... Σύνταξη και Συντακτική Ανάλυση 13 Παράδειγµα κατασκευής γραµµατικής (1) Συνήθως γίνεται µε χρήση της τεχνικής διαίρει και βασίλευε (divide nd onquer) Παράδειγµα: κατασκευή της γλώσσας των δηλώσεων της Jv: αρχικά, η δήλωση έχει ένα όνοµα τύπου στη συνέχεια µια ακολουθία από µεταβλητές που διαχωρίζονται µε κόµµατα (όπου κάθε µεταβλητή µπορεί να πάρει µια αρχική τιµή) και στο τέλος ένα ερωτηµατικό (semiolon) flot ; oolen,, ; int = 1,, = 1 + 2; Σύνταξη και Συντακτική Ανάλυση 14 Παράδειγµα κατασκευής γραµµατικής (2) Αρχικά ας αγνοήσουµε την πιθανή ύπαρξη αρχικοποιητών: <vr-del> ::= <type-nme> <delrtor-list> ; Ο κανόνας για τα ονόµατα των πρωτόγονων τύπων (primitive types) της Jv είναι απλούστατος: <type-nme> ::= oolen yte short int long hr flot doule Παράδειγµα κατασκευής γραµµατικής (3) Η ακολουθία των µεταβλητών που διαχωρίζονται µε κόµµατα έχει ως εξής: <delrtor-list> ::= <delrtor> <delrtor>, <delrtor-list> Όπου ξανά, έχουµε προς το παρόν αγνοήσει τους πιθανούς αρχικοποιητές των µεταβλητών Σηµείωση: δεν παίρνουµε υπόψη κατασκευασµένους τύπους (onstruted types): ονόµατα κλάσεων, ονόµατα διεπαφών (interfes), και τύπους πινάκων Σύνταξη και Συντακτική Ανάλυση 15 Σύνταξη και Συντακτική Ανάλυση 16 Παράδειγµα κατασκευής γραµµατικής (4) Οι δηλωτές µεταβλητών, µε ή χωρίς αρχικοποιήσεις, ορίζονται ως: <delrtor> ::= <vrile-nme> <vrile-nme> = <expr> Για ολόκληρη τη Jv: Πρέπει να επιτρέψουµε και ζεύγη από αγκύλες µετά το όνοµα των µεταβλητών για τη δήλωση των πινάκων Πρέπει επίσης να ορίσουµε και τη σύνταξη των αρχικοποιητών πινάκων (Φυσικά θέλουµε και ορισµούς για τα µη τερµατικά σύµβολα <vrile-nme> και <expr>) Τί αποτελεί λεκτική µονάδα; Όποια κοµµάτια της γλώσσας επιλέξουµε να θεωρήσουµε ως µη κατασκευαζόµενα από µικρότερα κοµµάτια Μεταβλητές (i), λέξεις κλειδιά (if), τελεστές (==,++), σταθερές (123.4), κ.λπ. Οι γραµµατικές που έχουµε ορίσει δίνουν τη δοµή των φράσεων (phrse struture): πως το πρόγραµµα κατασκευάζεται από µια σειρά λεκτικών µονάδων Πρέπει επιπλέον να ορίσουµε και τη λεκτική δοµή (lexil struture): πως ένα αρχείο χωρίζεται σε λεκτικές µονάδες Σύνταξη και Συντακτική Ανάλυση 17 Σύνταξη και Συντακτική Ανάλυση 18
4 ύο επιλογές ορισµού της λεκτικής δοµής Με µια κοινή γραµµατική Οι χαρακτήρες είναι οι µοναδικές λεκτικές µονάδες Συνήθως δεν ακολουθείται αυτή η επιλογή: κενά και σχόλια περιπλέκουν αρκετά τη γραµµατική και την καθιστούν µη αναγνώσιµη Με ξεχωριστές γραµµατικές 1. Μία που ορίζει πώς προκύπτουν οι λεκτικές µονάδες από ένα αρχείο µε χαρακτήρες Η γραµµατική αυτή συνήθως είναι µια κανονική γραµµατική (regulr grmmr) και χρησιµοποιείται από το λεκτικό αναλυτή (snner snner) 2. Μία που ορίζει πως προκύπτουν τα συντακτικά δένδρα από µία ακολουθία λεκτικών µονάδων Η γραµµατική αυτή συνήθως είναι µια γραµµατική ελεύθερη συµφραζοµένων (ontext-free grmmr) και χρησιµοποιείται από το συντακτικό αναλυτή (prser prser) Σύνταξη και Συντακτική Ανάλυση 19 Ιστορικές σηµειώσεις (1) Παλιά, κάποιες γλώσσες προγραµµατισµού δε διαχώριζαν τη λεκτική από την φραστική δοµή Παλιές εκδόσεις της Fortrn και της Algol επέτρεπαν κενά σε οποιοδήποτε σηµείο, ακόµα και στο µέσο µιας λέξης κλειδί! Άλλες γλώσσες, π.χ. η PL/I, επιτρέπουν τη χρήση λέξεων κλειδιών ως µεταβλητές (Το ίδιο συµβαίνει και στην ML, αλλά εκεί δεν αποτελεί πρόβληµα.) Τα παραπάνω προσθέτουν δυσκολία στην λεκτική και συντακτική ανάλυση και µειώνουν την αναγνωσιµότητα των προγραµµάτων Σύνταξη και Συντακτική Ανάλυση 20 Ιστορικές σηµειώσεις (2) Κάποιες γλώσσες έχουν λεκτική δοµή σταθερής µορφής (fixed-formt ) τα κενά είναι σηµαντικά Μία εντολή ανά γραµµή (π.χ. της διάτρητης κάρτας) Οι πρώτες 7 θέσεις κάθε γραµµής για την ταµπέλα (lel) Οι πρώτες διάλεκτοι της Fortrn, Cool, και της Bsi Σχεδόν οι περισσότερες µοντέρνες γλώσσες είναι ελεύθερης µορφής (free-formt ): τα κενά αγνοούνται Π.χ. Algol, Psl, Jv Μερικές άλλες (C, C++) διαφέρουν λίγο λόγω του προεπεξεργαστή Σύνταξη και Συντακτική Ανάλυση 21 Άλλες µορφές γραµµατικών Μικρές διαφοροποιήσεις της µορφής Bkus-Nur (BNF) Χρήση ή = αντί για ::= Όχι <> αλλά κάποιο ειδικό font ή χρήση αποστρόφων για τις λεκτικές µονάδες ώστε να ξεχωρίζονται εύκολα από τα µη τερµατικά σύµβολα Επεκτάσεις της µορφής Bkus-Nur (EBNF) Πρόσθετος συµβολισµός για την απλοποίηση κάποιων κανόνων: {x} υποδηλώνει µηδέν ή περισσότερες επαναλήψεις του x [x] υποδηλώνει ότι το x είναι προαιρετικό (δηλαδή x <empty>) () για οµαδοποίηση οπουδήποτε για να υποδηλώσει επιλογή Αποστρόφους γύρω από τις λεκτικές µονάδες ούτως ώστε να ξεχωρίζονται από τα παραπάνω µετασύµβολα Συντακτικά διαγράµµατα Σύνταξη και Συντακτική Ανάλυση 22 Παραδείγµατα EBNF <if-stmt> ::= if <expr> then <stmt> [else <stmt>] <stmt-list> ::= {<stmt> ;} <thing-list> ::= { (<stmt> <delrtion>) ;} Συντακτικά διαγράµµατα (1) Έστω ότι έχουµε µια γραµµατική σε EBNF Ο κάθε κανόνας παραγωγής µετατρέπεται σε µια σειρά από κουτιά Ορθογώνια για τα µη τερµατικά σύµβολα Οβάλ για τα τερµατικά σύµβολα Τα παραπάνω ενώνονται µε βέλη (Πιθανώς κάποια βέλη να παρακάµπτουν κάποια από τα κουτιά.) <if-stmt> ::= if <expr> then <stmt> [ else <stmt> ] if-stmt if expr then stmt else stmt Σύνταξη και Συντακτική Ανάλυση 23 Σύνταξη και Συντακτική Ανάλυση 24
5 Συντακτικά διαγράµµατα (2) Πολλαπλοί κανόνες παραγωγής χρησιµοποιούν διακλαδώσεις (rnhing) exp Η επανάληψη υποδηλώνεται µε χρήση βρόχων ::= <ddend> {+ <ddend>} exp + exp exp * exp ( exp ) exp ddend + Σύνταξη και Συντακτική Ανάλυση 25 Παράδειγµα διαφορετικού συµβολισµού EBNF WhileSttement: while ( Expression ) Sttement DoSttement: do Sttement while ( Expression ); ForSttement: for ( ForInit opt ; Expression opt ; ForUpdte opt ) Sttement από το βιβλίο The Jv Lnguge Speifition, Jmes Gosling et l. Σύνταξη και Συντακτική Ανάλυση 26 Τρεις ισοδύναµες γραµµατικές G1: <suexp> ::= <suexp> - <suexp> Από τη Σύνταξη προς τη Σηµασιολογία G2: <suexp> ::= <vr> - <suexp> <vr> <vr> ::= G3: <suexp> ::= <suexp> - <vr> <vr> <vr> ::= Και οι τρεις γραµµατικές ορίζουν την ίδια γλώσσα: τη γλώσσα όλων των συµβολοσειρών που περιλαµβάνουν ένα ή περισσότερα,, ή τα οποία διαχωρίζονται από ένα µείον. Αλλά... Σύνταξη και Συντακτική Ανάλυση 27 Σύνταξη και Συντακτική Ανάλυση 28 G2 prse tree: G3 prse tree: <suexp> <vr> - <suexp> <vr> - <suexp> <suexp> - <vr> <vr> <suexp> <suexp> - <vr> <vr> Γιατί είναι σηµαντικά τα συντακτικά δένδρα; Θέλουµε η δοµή του συντακτικού δένδρου να αντικατοπτρίζει τη σηµασιολογία της συµβολοσειράς που αντιπροσωπεύει Αυτό κάνει το σχεδιασµό της γλώσσας πιο δύσκολο: ενδιαφερόµαστε για τη δοµή του κάθε συντακτικού δένδρου όχι µόνο για την συµβολοσειρά των φύλλων του Τα συντακτικά δένδρα είναι το µέρος που η σύνταξη αρχίζει να συναντά τη σηµασιολογία των γλωσσών Σύνταξη και Συντακτική Ανάλυση 29 Σύνταξη και Συντακτική Ανάλυση 30
6 Τελεστές (opertors) Τελεστές χρησιµοποιούνται για λειτουργίες που γίνονται συχνά, π.χ. πρόσθεση, αφαίρεση, πολλαπλασιασµό, Ο όρος τελεστής αναφέρεται τόσο στη λεκτική µονάδα (π.χ. +, *) όσο και στη λειτουργία αυτή καθ αυτή Μοναδιαίοι τελεστές δέχονται ένα όρισµα: -1 υαδικοί τελεστές δέχονται δύο ορίσµατα: 1+2 Τριαδικοί τελεστές δέχονται τρία ορίσµατα:?: Στις περισσότερες γλώσσες Οι δυαδικοί τελεστές γράφονται σε infix µορφή: π.χ. 1+2 Οι µοναδιαίοι τελεστές γράφονται σε prefix (-2) ή σε postfix µορφή (i++) Σύνταξη και Συντακτική Ανάλυση 31 Προτεραιότητα (preedene) τελεστών Έστω η γραµµατική G4: ::= + * ( ) Ένα συντακτικό δένδρο για τη συµβολοσειρά +* είναι το <exp > <exp > * <exp > + Στο δένδρο αυτό η πρόσθεση γίνεται πριν από τον πολλαπλασιασµό, κάτι που δεν είναι σε αρµονία µε τις συνήθεις προτεραιότητες των τελεστών + και * Σύνταξη και Συντακτική Ανάλυση 32 Προτεραιότητα τελεστών στη γραµµατική Για να έχουµε τη σωστή προτεραιότητα τελεστών, αλλάζουµε τη γραµµατική µε τέτοιο τρόπο ώστε ο τελεστής µε την µεγαλύτερη προτεραιότητα να καταλήγει πιο κάτω στο συντακτικό δένδρο G5: ::= + <mulexp> <mulexp> ::= <mulexp> * <mulexp> ( ) Παραδείγµατα προτεραιότητας τελεστών C (15 επίπεδα προτεραιότητας πάρα πολλά;) = <? * p + * : 1 << d () Psl (5 επίπεδα όχι αρκετά;) <= 0 or 100 <= Συντακτικό λάθος! Smlltlk (1 επίπεδο για όλους τους δυαδικούς τελεστές) + * Σύνταξη και Συντακτική Ανάλυση 33 Σύνταξη και Συντακτική Ανάλυση 34 Συντακτικό δένδρο µε σωστή προτεραιότητα Προσεταιριστικότητα (ssoitivity) τελεστών G5 prse tree: + <mulexp> <mulexp> + <mulexp> + <mulexp> <mulexp> + + <mulexp> <mulexp> <mulexp> <mulexp> * <mulexp> Η γραµµατική G5 παράγει µόνο αυτό το δένδρο για +*. Αναγνωρίζει την ίδια γλώσσα µε τη G4, αλλά δεν παράγει πλέον δένδρα µε λάθος προτεραιότητα τελεστών. Σύνταξη και Συντακτική Ανάλυση 35 Η γραµµατική G5 παράγει τα παραπάνω δένδρα για ++. Το πρώτο από αυτά δεν αντικατοπτρίζει τη συνήθη προσεταιριστικότητα του τελεστή +. Σύνταξη και Συντακτική Ανάλυση 36
7 Προσεταιριστικότητα τελεστών Έχουν χρησιµότητα όταν η σειρά της αποτίµησης δεν καθορίζεται από παρενθέσεις ή προτεραιότητα τελεστών Οι αριστερά προσεταιριστικοί τελεστές οµαδοποιούν από αριστερά προς τα δεξιά: +++d = ((+)+)+d Οι δεξιά προσεταιριστικοί τελεστές οµαδοποιούν από δεξιά προς τα αριστερά: +++d = +(+(+d)) Στις περισσότερες γλώσσες, οι περισσότεροι τελεστές είναι αριστερά προσεταιριστικοί, αλλά υπάρχουν και εξαιρέσεις Παραδείγµατα προσεταιριστικότητας C ML <<<< ==0 τελεστέςείναι αριστερά προσεταιριστικοί δεξιά προσεταιριστικός (ανάθεση) τελεστές είναι αριστερά προσεταιριστικοί 1::2::nil δεξιά προσεταιριστικός (κατασκευή λίστας) Fortrn /* **** τελεστές είναι αριστερά προσεταιριστικοί δεξιά προσεταιριστικός (ύψωση σε δύναµη) Σύνταξη και Συντακτική Ανάλυση 37 Σύνταξη και Συντακτική Ανάλυση 38 Προσεταιριστικότητα στη γραµµατική G5: ::= + <mulexp> <mulexp> ::= <mulexp> * <mulexp> ( ) Για να διορθώσουµε το πρόβληµα, τροποποιούµε τη γραµµατική ώστε να κάνουµε δένδρα µε τελεστές + να µεγαλώνουν προς τα αριστερά (παρόµοια για τον *) G6: ::= + <mulexp> <mulexp> <mulexp> ::= <mulexp> * ::= ( ) Σύνταξη και Συντακτική Ανάλυση 39 ένδρο µε σωστή προσεταιριστικότητα <mulexp> + <mulexp> + <mulexp> Η γραµµατική G6 παράγει µόνο αυτό το δένδρο για ++. Παράγει την ίδια γλώσσα µε τη G5, αλλά δεν παράγει πλέον δένδρα µε λάθος προσεταιριστικότητα τελεστών. Σύνταξη και Συντακτική Ανάλυση 40 Πρακτική άσκηση Ξεκινώντας από τη γραµµατική G6: ::= + <mulexp> <mulexp> <mulexp> ::= <mulexp> * ::= ( ) 1. Προσθέστε έναν αριστερά προσεταιριστικό τελεστή &, µε προτεραιότητα µικρότερη από όλους τους άλλους 2. Στη συνέχεια προσθέστε ένα δεξιά προσεταιριστικό τελεστή **, µε προτεραιότητα µεγαλύτερη από όλους τους άλλους Πολλαπλή ερµηνεία (miguity) Η γραµµατική G4 είναι διφορούµενη (miguous): παράγει περισσότερα από ένα συντακτικά δένδρα για την ίδια συµβολοσειρά Όµως η επιδιόρθωση των προβληµάτων προτεραιότητας και προσεταιριστικότητας των τελεστών εξαφάνισε όλη την ασάφεια στη συγκεκριµένη γραµµατική Αυτό είναι επιθυµητό: το συντακτικό δένδρο υποδηλώνει τη σηµασιολογία του προγράµµατος και δε θέλουµε αυτή να είναι διφορούµενη Όµως υπάρχουν και άλλοι λόγοι που µια γραµµατική είναι διφορούµενη, όχι µόνο λόγοι σχετικοί µε τους τελεστές Σύνταξη και Συντακτική Ανάλυση 41 Σύνταξη και Συντακτική Ανάλυση 42
8 Το πρόβληµα του ξεκρέµαστου else <stmt> ::= <if-stmt> s1 s2 <if-stmt> ::= if <expr> then <stmt> else <stmt> if <expr> then <stmt> <expr> ::= e1 e2 <if-stm t> if then <stm t> else e1 <if-stm t> if then <stmt> e2 s1 <stmt> s2 Η γραµµατική αυτή είναι διφορούµενη ως προς τo ξεκρέµαστο else ( dngling-else miguity ). Η παρακάτω εντολή if e1 then if e2 then s1 else s2 έχει δύο συντακτικά δένδρα Σύνταξη και Συντακτική Ανάλυση 43 <if-stm t> if then <stmt> e1 <if-stm t> if <ex p> then <stm t> else e2 s1 <stmt> s2 Οι περισσότερες γλώσσες που έχουν αυτό το πρόβληµα επιλέγουν το κάτω συντακτικό δένδρο: το else πηγαίνει µε το κοντινότερο αταίριαστο then Σύνταξη και Συντακτική Ανάλυση 44 ιόρθωση του προβλήµατος (1) <stmt> ::= <if-stmt> s1 s2 <if-stmt> ::= if <expr> then <stmt> else <stmt> if <expr> then <stmt> <expr> ::= e1 e2 Θέλουµε να επιβάλλουµε ότι εάν αυτό επεκταθεί σε ένα if, τότε το if πρέπει ήδη να έχει το δικό του else. Πρώτα, δηµιουργούµε ένα νέο µη τερµατικό <full-stmt> που παράγει όλες τις εντολές που παράγονται από το <stmt>, αλλά απαγορεύει τις if εντολές χωρίς else ιόρθωση του προβλήµατος (2) Μετά χρησιµοποιούµε το νέο µη τερµατικό εδώ <stmt> ::= <if-stmt> s1 s2 <if-stmt> ::= if <expr> then <full-stmt> else <stmt> if <expr> then <stmt> <expr> ::= e1 e2 Το αποτέλεσµα είναι ότι η παραπάνω γραµµατική µπορεί να ταιριάξει ένα else µε ένα if µόνο όταν όλα τα κοντινά if έχουν ήδη κάποιο else ως ταίρι τους. <full-stmt> ::= <full-if> s1 s2 <full-if> ::= if <expr> then <full-stmt> else <full-stmt> Σύνταξη και Συντακτική Ανάλυση 45 Σύνταξη και Συντακτική Ανάλυση 46 Τώρα παράγουµε µόνο το συντακτικό δένδρο <if-stmt> if then <stmt> e1 <if-stmt> Ξεκρέµαστα elseκαι αναγνωσιµότητα ιορθώσαµε τη γραµµατική, αλλά Το πρόβληµα στη γραµµατική αντικατοπτρίζει κάποιο πρόβληµα στη γλώσσα, την οποία δεν αλλάξαµε Μια ακολουθία από if-then-else δεν είναι εύκολα αναγνώσιµη, ειδικά εάν κάποια από τα else λείπουν if then <full-stmt> else <stmt> e2 s1 s2 int =0; if (0==0) if (0==1) =1; else =2; Ποια είναι η τιµή του µετά την εκτέλεση του προγράµµατος; Σύνταξη και Συντακτική Ανάλυση 47 Σύνταξη και Συντακτική Ανάλυση 48
9 Καλύτερα στυλ προγραµµατισµού Γλώσσες χωρίς ξεκρέµαστα else int =0; if (0==0) if (0==1) =1; else =2; int =0; if (0==0) { if (0==1) =1; else =2; } Καλύτερο: σωστή στοίχιση Ακόµα καλύτερο: η χρήση µπλοκ δείχνει καθαρά τη δοµή του κώδικα Μερικές γλώσσες ορίζουν τα if-then-else µε τρόπο που επιβάλλει τη σαφήνεια στη χρήση τους Η Algol δεν επιτρέπει µέσα στο then να αρχίζει άµεσα κάποιο άλλο if (αλλά µπορεί να αρχίζει ένα µπλοκ µε ένα άλλο if) Η Algol 68 επιβάλλει σε κάθε if να τερµατίζεται µε ένα fi (υπάρχουν επίσης do-od και se-es) Η Ad επιβάλλει σε κάθε if να τερµατίζεται µε ένα end if Σύνταξη και Συντακτική Ανάλυση 49 Σύνταξη και Συντακτική Ανάλυση 50 Γραµµατική για ολόκληρη τη γλώσσα Κάθε ρεαλιστική γλώσσα περιέχει πολλά µη τερµατικά σύµβολα Ειδικά εάν από τη γραµµατική έχει εξαλειφθεί η ασάφεια Τα επιπλέον µη τερµατικά καθορίζουν τον τρόπο µε τον οποίο προκύπτει ένα µοναδικό συντακτικό δένδρο Όταν κατασκευαστεί το συντακτικό δένδρο, τα επιπλέον µη τερµατικά δεν έχουν κάποια χρησιµότητα πλέον Οι υλοποιήσεις των γλωσσών συνήθως αποθηκεύουν µια συνεπτυγµένη µορφή του συντακτικού δένδρου, η οποία ονοµάζεται αφηρηµένο συντακτικό δένδρο Σύνταξη και Συντακτική Ανάλυση 51 Συγκεκριµένο συντακτικό δένδρο + <mulexp> <mulexp> + <mulexp> + + Αφηρηµένο συντακτικό δένδρο Σύνταξη και Συντακτική Ανάλυση 52 Συµπερασµατικά Για τον ορισµό του συντακτικού (και όχι µόνο!) των γλωσσών προγραµµατισµού χρησιµοποιούµε γραµµατικές Οι γραµµατικές ορίζουν το ποια είναι τα επιτρεπτά προγράµµατα µιας γλώσσας, αλλά και το συντακτικό δένδρο για αυτά τα προγράµµατα το δένδρο µε τη σειρά του ορίζει τη σειρά εκτέλεσης των εντολών και κατά συνέπεια συνεισφέρει στον ορισµό της σηµασιολογίας Υπάρχει ισχυρή σύνδεση µεταξύ θεωρίας και πράξης ύο γραµµατικές, δύο µέρη του µεταγλωττιστή (ompiler) Σηµείωση: Υπάρχουν προγράµµατα, γεννήτριες συντακτικών αναλυτών (prser genertors), που µπορούν να δηµιουργήσουν αυτόµατα τον κώδικα του λεκτικού και του συντακτικού αναλυτή από τη γραµµατική µιας γλώσσας Σύνταξη και Συντακτική Ανάλυση 53
Σύνταξη & Συντακτική Ανάλυση
Μια γραμματική για τα Αγγλικά Σύνταξη & Συντακτική Ανάλυση Rene Mgritte, Le Seize Septemre Μια πρόταση αποτελείται από μια ουσιαστική φράση, ένα ρήμα, και μια ουσιαστική φράση Μια ουσιαστική φράση αποτελείται
Σύνταξη & Συντακτική Ανάλυση
Σύνταξη & Συντακτική Ανάλυση Μια γραμματική για τα Αγγλικά Μια πρόταση αποτελείται από μια ουσιαστική φράση, ένα ρήμα, και μια ουσιαστική φράση ::= Μια ουσιαστική φράση αποτελείται από
Κεφάλαιο 2: Τυπικές γλώσσες
Κεφάλαιο 2: Τυπικές γλώσσες (μέρος 2ο) Νίκος Παπασπύρου, Κωστής Σαγώνας Μεταγλωττιστές Μάρτιος 2017 47 / 216 Γλώσσες χωρίς συμφραζόμενα (i) Γραμματικές χωρίς συμφραζόμενα: Σε κάθε παραγωγή ένα μη τερματικό
Σχεδίαση Γλωσσών Προγραμματισμού Συντακτική Ανάλυση ΙII. Εαρινό Εξάμηνο Lec 11 26/03/2019 Διδάσκων: Γεώργιος Χρ. Μακρής
Σχεδίαση Γλωσσών Προγραμματισμού Συντακτική Ανάλυση ΙII Εαρινό Εξάμηνο 2018-2019 Lec 11 26/03/2019 Διδάσκων: Γεώργιος Χρ. Μακρής Γραμματικές Μία γραμματική ονομάζεται αναδρομική εφόσον επιτρέπει παραγωγές
Ανάπτυξη και Σχεδίαση Λογισμικού
Ανάπτυξη και Σχεδίαση Λογισμικού Η γλώσσα προγραμματισμού C Γεώργιος Δημητρίου Εκφράσεις και Λίγες Εντολές Οι εκφράσεις της C Τελεστές Απλές και σύνθετες εντολές Εντολές ελέγχου (επιλογής) Εισαγωγή σε
ΜΕΤΑΓΛΩΤΤΙΣΤΕΣ. Στις βασικές έννοιες που σχετίζονται με τη λεξική ανάλυση. Στη δήλωση ορισμό κανονικών εκφράσεων
ΜΕΤΑΓΛΩΤΤΙΣΤΕΣ 2 Ο Εργαστηριακό Μάθημα Λεξική Ανάλυση Σκοπός: Το μάθημα αυτό αναφέρεται: Στις βασικές έννοιες που σχετίζονται με τη λεξική ανάλυση Στη δήλωση ορισμό κανονικών εκφράσεων Θεωρία Πρόλογος
Εισαγωγή στην C. Μορφή Προγράµµατος σε γλώσσα C
Εισαγωγή στην C Μορφή Προγράµµατος σε γλώσσα C Τµήµα Α Με την εντολή include συµπεριλαµβάνω στο πρόγραµµα τα πρότυπα των συναρτήσεων εισόδου/εξόδου της C.Το αρχείο κεφαλίδας stdio.h είναι ένας κατάλογος
a = 10; a = k; int a,b,c; a = b = c = 10;
C: Από τη Θεωρία στην Εφαρµογή Κεφάλαιο 4 ο Τελεστές Γ. Σ. Τσελίκης Ν. Δ. Τσελίκας Ο τελεστής εκχώρησης = Ο τελεστής = χρησιµοποιείται για την απόδοση τιµής (ή αλλιώς ανάθεση τιµής) σε µία µεταβλητή Π.χ.
Γραµµατικές για Κανονικές Γλώσσες
Κανονικές Γραµµατικές Γραµµατικές για Κανονικές Γλώσσες Ταξινόµηση Γραµµατικών εξιά Παραγωγικές Γραµµατικές εξιά Παραγωγικές Γραµµατικές και NFA Αριστερά Παραγωγικές Γραµµατικές Κανονικές Γραµµατικές Γραµµατικές
Μεταγλωττιστές. Γιώργος Δημητρίου. Μάθημα 2 ο. Πανεπιστήμιο Θεσσαλίας - Τμήμα Ηλεκτρολόγων Μηχανικών & Μηχανικών Υπολογιστών
Γιώργος Δημητρίου Μάθημα 2 ο Αλφάβητα και Γλώσσες Αλφάβητο: Ένα μη κενό και πεπερασμένο σύνολο συμβόλων Γλώσσα: Ένα οποιοδήποτε υποσύνολο των συμβολοσειρών ενός αλφαβήτου (οι προτάσεις της γλώσσας, πχ.
Μεταγλωττιστές. Γιώργος Δημητρίου. Μάθημα 1 ο. Πανεπιστήμιο Θεσσαλίας - Τμήμα Ηλεκτρολόγων Μηχανικών & Μηχανικών Υπολογιστών
Γιώργος Δημητρίου Μάθημα 1 ο Γλώσσα - Μετάφραση Γλώσσα προγραμματισμού = Αναπαράσταση αλγορίθμων Ευκολία χρήσης Ακρίβεια και πληρότητα περιγραφής, όχι διφορούμενη! Μία περιγραφή για όλες τις μηχανές Μετάφραση
2.1. Εντολές. 2.2. Σχόλια. 2.3. Τύποι Δεδομένων
2 Βασικές Εντολές 2.1. Εντολές Οι στην Java ακολουθούν το πρότυπο της γλώσσας C. Έτσι, κάθε εντολή που γράφουμε στη Java θα πρέπει να τελειώνει με το ερωτηματικό (;). Όπως και η C έτσι και η Java επιτρέπει
Εισαγωγή στο Bison. Μεταγλωττιστές, Χειμερινό εξάμηνο
Εισαγωγή στο Bison Μεταγλωττιστές, Χειμερινό εξάμηνο 2014-2015 Συντακτική Ανάλυση Αποτελεί την δεύτερη φάση της μετάφρασης. Εύρεση της σχέσης που υπάρχει των λεκτικών μονάδων ενός προγράμματος. Παράδειγμα
Σχολικό Βιβλίο - Κεφάλαιο 7 ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΜΕ PASCAL ΠΑΡΟΥΣΙΑΣΗ 13
Σχολικό Βιβλίο - Κεφάλαιο 7 ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΜΕ PASCAL ΠΑΡΟΥΣΙΑΣΗ 13 ΙΣΤΟΡΙΚΑ Παρουσιάστηκε το 1970 από το Niklaus Wirth Προγενέστερη γλώσσα ήταν η Algol 60 Είναι δομημένη γλώσσα προγραμματισμού υψηλού
Μεταγλωττιστές. Δημήτρης Μιχαήλ. Ακ. Έτος 2011-2012. Ανοδικές Μέθοδοι Συντακτικής Ανάλυσης. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο
Μεταγλωττιστές Ανοδικές Μέθοδοι Συντακτικής Ανάλυσης Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Ακ. Έτος 2011-2012 Ανοδική Κατασκευή Συντακτικού Δέντρου κατασκευή δέντρου
Στοιχεία Θεωρίας Υπολογισµού (1): Τυπικές Γλώσσες, Γραµµατικές
Στοιχεία Θεωρίας Υπολογισµού (1): Τυπικές Γλώσσες, Γραµµατικές Ορέστης Τελέλης telelis@unipi.gr Τµήµα Ψηφιακών Συστηµάτων, Πανεπιστήµιο Πειραιώς Ο. Τελέλης Πανεπιστήµιο Πειραιώς Θεωρία Υπολογισµού 1 /
Ποιές οι θεµελιώδεις δυνατότητες και ποιοί οι εγγενείς περιορισµοί των υπολογιστών ; Τί µπορούµε και τί δε µπορούµε να υπολογίσουµε (και γιατί);
Μοντελοποίηση του Υπολογισµού Στοιχεία Θεωρίας Υπολογισµού (): Τυπικές Γλώσσες, Γραµµατικές Ορέστης Τελέλης telelis@unipi.gr Τµήµα Ψηφιακών Συστηµάτων, Πανεπιστήµιο Πειραιώς Ποιές οι θεµελιώδεις δυνατότητες
Στοιχεία Θεωρίας Υπολογισµού (2): Πεπερασµένα Αυτόµατα, Κανονικές Εκφράσεις
Στοιχεία Θεωρίας Υπολογισµού (2): Πεπερασµένα Αυτόµατα, Κανονικές Εκφράσεις Ορέστης Τελέλης telelis@unipi.gr Τµήµα Ψηφιακών Συστηµάτων, Πανεπιστήµιο Πειραιώς Ο. Τελέλης Πανεπιστήµιο Πειραιώς Θεωρία Υπολογισµού
Μεταγλωττιστές. Γιώργος Δημητρίου. Μάθημα 8 ο. Πανεπιστήμιο Θεσσαλίας - Τμήμα Ηλεκτρολόγων Μηχανικών & Μηχανικών Υπολογιστών
Γιώργος Δημητρίου Μάθημα 8 ο Μετάφραση Οδηγούμενη από τη Σύνταξη Ο ΣΑ καλεί τις ρουτίνες που εκτελούν τη σημασιολογική ανάλυση και παράγουν τον ενδιάμεσο κώδικα Σημασιολογικές πληροφορίες μπορούν να μεταφέρονται
Γενικές Παρατηρήσεις. Μη Κανονικές Γλώσσες - Χωρίς Συµφραζόµενα (1) Το Λήµµα της Αντλησης. Χρήση του Λήµµατος Αντλησης.
Γενικές Παρατηρήσεις Μη Κανονικές Γλώσσες - Χωρίς Συµφραζόµενα () Ορέστης Τελέλης telelis@unipi.gr Τµήµα Ψηφιακών Συστηµάτων, Πανεπιστήµιο Πειραιώς Υπάρχουν µη κανονικές γλώσσες, π.χ., B = { n n n }. Αυτό
Πίνακας Περιεχοµένων Πρόλογος Κεφάλαιο Βασικές εισαγωγικές έννοιες
Πίνακας Περιεχοµένων Πρόλογος...vii Κεφάλαιο 1:Βασικές εισαγωγικές έννοιες...1 1.1 Η δοµή του µεταγλωττιστή...2 1.2 Η διαδικασία µεταγλώττισης...3 1.2.1 Η Λεξική Ανάλυση...6 1.2.2 Η Συντακτική Ανάλυση...6
Πανεπιστήμιο Θεσσαλίας Τμήμα Πληροφορικής
Πανεπιστήμιο Θεσσαλίας Τμήμα Πληροφορικής Δεύτερη Σειρά Ασκήσεων 22 Νοεμβρίου 2016 (χειρόγραφη και ηλεκτρονική παράδοση 9 Δεκεμβρίου) Άσκηση 1: Θεωρήστε τη γραμματική με κανόνες: Α B a A a c B B b A b
ΦΥΣ-151. Ηλεκτρονικοί Υπολογιστές Ι (FORTRAN 77) (Άνοιξη 2004)
1 ΦΥΣ-151. Ηλεκτρονικοί Υπολογιστές Ι (FORTRAN 77) (Άνοιξη 2004) ιάλεξη 1 1.1 ΕΙΣΑΓΩΓΗ ΣΤΗ FORTRAN 77 Ένα πρόγραµµα σε οποιαδήποτε γλώσσα προγραµµατισµού δεν τίποτα άλλο από µια σειρά εντολών που πρέπει
Εισαγωγή στο Bison. Μεταγλωττιστές, Χειμερινό εξάμηνο
Εισαγωγή στο Bison Μεταγλωττιστές, Χειμερινό εξάμηνο 2016-2017 Συντακτική Ανάλυση Αποτελεί την δεύτερη φάση της μετάφρασης. Εύρεση της σχέσης που υπάρχει των λεκτικών μονάδων ενός προγράμματος. Παράδειγμα
Η γλώσσα προγραμματισμού Strange
Προγραμματιστική άσκηση: Η γλώσσα προγραμματισμού Strange Η Strange είναι μια μικρή γλώσσα προγραμματισμού. Παρόλο που οι προγραμματιστικές της ικανότητες είναι μικρές, η εκπαιδευτική αυτή γλώσσα περιέχει
Εισαγωγή στον Προγραμματισμό
Εισαγωγή στον Προγραμματισμό Έλεγχος Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Ακ. Έτος 2012-2013 Σχεσιακοί Τελεστές και Ισότητας Ένα πρόγραμμα εκτός από αριθμητικές πράξεις
ΚΕΦΑΛΑΙΟ 6: Γλώσσες. 6.1 Ιστορική εξέλιξη 6.4 Υλοποίηση γλώσσας. Κεφάλαιο 6: «Γλώσσες Προγραµµατισµού»
ΚΕΦΑΛΑΙΟ 6: Γλώσσες Προγραµµατισµού 6.1 Ιστορική εξέλιξη 6.4 Υλοποίηση γλώσσας 1 6.1 Γενιές γλωσσών προγραµµατισµού 2 Δεύτερη γενιά: γλώσσα assembly Ένα µνηµονικό σύστηµα για την αναπαράσταση προγραµµάτων
ΚΕΦΑΛΑΙΟ 7 ο. Έτσι ο προγραµµατισµός µε τη ΓΛΩΣΣΑ εστιάζεται στην ανάπτυξη του αλγορίθµου και τη µετατροπή του σε σωστό πρόγραµµα.
ΚΕΦΑΛΑΙΟ 7 ο 1. Επιλογή της κατάλληλης γλώσσας προγραµµατισµού Εκατοντάδες γλώσσες προγραµµατισµού χρησιµοποιούνται όπως αναφέρθηκε σήµερα για την επίλυση των προβληµάτων µε τον υπολογιστή, τη δηµιουργία
Εισαγωγή στον Προγραμματισμό
Εισαγωγή στον Προγραμματισμό Πίνακες Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Ακ. Έτος 2012-2013 Πίνακες Πολλές φορές θέλουμε να κρατήσουμε στην μνήμη πολλά αντικείμενα
Βασικά στοιχεία της Java
Βασικά στοιχεία της Java προτάσεις, εκφράσεις, µεταβλητές, σταθερές, τελεστές Ορισµοί Πρόταση (statement) είναι µία απλή εντολή σε µία γλώσσα προγραµµατισµού. Γιαπαράδειγµα: int x=12; Έκφραση (expression)
Έστω συμβολοσειρά Το σύνολο FIRST περιέχει τα τερματικά σύμβολα από τα οποία αρχίζουν οι συμβολοσειρές που παράγονται από την
Βοηθητικές έννοιες (i) Σύνολα FIRST Έστω συμβολοσειρά Το σύνολο FIRST περιέχει τα τερματικά σύμβολα από τα οποία αρχίζουν οι συμβολοσειρές που παράγονται από την Αν a τότε a FIRST Αν τότε FIRST Νίκος Παπασπύρου,
C: Από τη Θεωρία στην Εφαρµογή 2 ο Κεφάλαιο
C: Από τη Θεωρία στην Εφαρµογή Κεφάλαιο 2 ο Τύποι Δεδοµένων Δήλωση Μεταβλητών Έξοδος Δεδοµένων Γ. Σ. Τσελίκης Ν. Δ. Τσελίκας Μνήµη και Μεταβλητές Σχέση Μνήµης Υπολογιστή και Μεταβλητών Η µνήµη (RAM) ενός
Βαθμός Σχόλια. lab5 PASS PASS PASS PASS PASS. Οριακά PASS - Καλή δουλειά
Α. Μ. Βαθμός Σχόλια 1183 1194 1238 1239 1240 1241 - Καλή δουλειά 1242 1243 1244 1245 - Κακή χρήση συναρτήσεων. Κάνεις τον ίδιο έλεγχο και εντός και εκτός της συνάρτησης. Θα έπρεπε να έχεις βρεί ένα τρόπο
Μεταγλωττιστές. Εργαστήριο 5. Εισαγωγή στο BISON. Γεννήτρια Συντακτικών Αναλυτών. 2 η Φάση Μεταγλώττισης Συντακτική Ανάλυση
Μεταγλωττιστές Εργαστήριο 5 Εισαγωγή στο BISON Γεννήτρια Συντακτικών Αναλυτών 2 η Φάση Μεταγλώττισης Συντακτική Ανάλυση Διδάσκοντες: Δρ. Γεώργιος Δημητρίου Δρ. Άχμεντ Μάχντι 2015-1016 Φάσεις Μεταγλώττισης
Τεχνητή Νοημοσύνη. 21η διάλεξη ( ) Ίων Ανδρουτσόπουλος.
Τεχνητή Νοημοσύνη 21η διάλεξη (2016-17) Ίων Ανδρουτσόπουλος http://www.aueb.gr/users/ion/ 1 Οι διαφάνειες αυτής της διάλεξης βασίζονται στα βιβλία: «Artificial Intelligence A Modern Approach» των. Russel
Π. Σταθοπούλου ή Οµάδα Α (Φοιτητές µε µονό αριθµό Μητρώου ) ιδασκαλία : Παρασκευή 11πµ-13µµ ΗΛ7
Π. Σταθοπούλου pstath@ece.upatras.gr ή pstath@upatras.gr Οµάδα Α (Φοιτητές µε µονό αριθµό Μητρώου ) ιδασκαλία : Παρασκευή 11πµ-13µµ ΗΛ7 Φροντιστήριο : ευτέρα 11πµ-12πµ ΗΛ4 Προηγούµενη ιάλεξη Προτάσεις,
Διασυνδεδεμένες Δομές. Δυαδικά Δέντρα. Προγραμματισμός II 1
Διασυνδεδεμένες Δομές Δυαδικά Δέντρα Προγραμματισμός II 1 lalis@inf.uth.gr Δέντρα Τα δέντρα είναι κλασικές αναδρομικές δομές Ένα δέντρο αποτελείται από υποδέντρα, καθένα από τα οποία μπορεί να θεωρηθεί
επιµέλεια Θοδωρής Πιερράτος
Βασικές έννοιες προγραµµατισµού Η ύλη που αναπτύσσεται σε αυτό το κεφάλαιο είναι συναφής µε την ύλη που αναπτύσσεται στο 2 ο κεφάλαιο. Όπου υπάρχουν διαφορές αναφέρονται ρητά. Προσέξτε ιδιαίτερα, πάντως,
Ανάπτυξη και Σχεδίαση Λογισμικού
Ανάπτυξη και Σχεδίαση Λογισμικού Η γλώσσα προγραμματισμού C Γεώργιος Δημητρίου Βασικά Στοιχεία Το αλφάβητο της C Οι βασικοί τύποι της C Δηλώσεις μεταβλητών Είσοδος/Έξοδος Βασικές εντολές της C Αλφάβητο
ΦΥΣ-151. Ηλεκτρονικοί Υπολογιστές Ι (FORTRAN 77) (Άνοιξη 2004)
8 ΦΥΣ-151. Ηλεκτρονικοί Υπολογιστές Ι (FORTRAN 77) (Άνοιξη 2004) ιάλεξη 2 2.1 ΜΕΤΑΒΛΗΤΕΣ (ΜΕΡΟΣ Β) Στην προηγούµενη διάλεξη µάθαµε ότι µπορούµε να χρησιµοποιούµε τη ρητή ή την αυτονόητη δήλωση µεταβλητών
Προβλήματα, αλγόριθμοι, ψευδοκώδικας
Προβλήματα, αλγόριθμοι, ψευδοκώδικας October 11, 2011 Στο μάθημα Αλγοριθμική και Δομές Δεδομένων θα ασχοληθούμε με ένα μέρος της διαδικασίας επίλυσης υπολογιστικών προβλημάτων. Συγκεκριμένα θα δούμε τι
Σύνοψη Προηγούµενου. Γλώσσες χωρίς Συµφραζόµενα (2) Ισοδυναµία CFG και PDA. Σε αυτό το µάθηµα. Αυτόµατα Στοίβας Pushdown Automata
Σύνοψη Προηγούµενου Γλώσσες χωρίς Συµφραζόµενα (2) Ορέστης Τελέλης telelis@unipi.gr Τµήµα Ψηφιακών Συστηµάτων, Πανεπιστήµιο Πειραιώς Αυτόµατα Στοίβας Pushdown utomata Ισοδυναµία µε τις Γλώσσες χωρίς Συµφραζόµενα:
int array[10]; double arr[5]; char pin[20]; Προγραµµατισµός Ι
Εισαγωγή Στον Προγραµµατισµό «C» Πίνακες Πανεπιστήµιο Πελοποννήσου Τµήµα Πληροφορικής & Τηλεπικοινωνιών Νικόλαος Δ. Τσελίκας Νικόλαος Προγραµµατισµός Δ. Τσελίκας Ι Πίνακες στη C Ένας πίνακας στη C είναι
3.1 Αριθμητικοί και Λογικοί Τελεστές, Μετατροπές Τύπου (Casting)
Εργαστήριο 3: 3.1 Αριθμητικοί και Λογικοί Τελεστές, Μετατροπές Τύπου (Casting) Η C++, όπως όλες οι γλώσσες προγραμματισμού, χρησιμοποιεί τελεστές για να εκτελέσει τις αριθμητικές και λογικές λειτουργίες.
Μεταγλωττιστές. Ενότητα 6: Λεκτική ανάλυση (Μέρος 2 ο ) Αγγελική Σγώρα Τμήμα Μηχανικών Πληροφορικής ΤΕ
Μεταγλωττιστές Ενότητα 6: Λεκτική ανάλυση (Μέρος 2 ο ) Αγγελική Σγώρα Τμήμα Μηχανικών Πληροφορικής ΤΕ Άδειες Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται σε άδειες χρήσης Creative Commons. Για εκπαιδευτικό
Κεφάλαιο 7 : Είδη, Τεχνικές, και Περιβάλλοντα Προγραµµατισµού
ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΥΠΟΛΟΓΙΣΤΩΝ Κεφάλαιο 7 : Είδη, Τεχνικές, και Περιβάλλοντα Προγραµµατισµού ( Απαντήσεις & Λύσεις Βιβλίου) 1. Σκοποί κεφαλαίου Κύκλος ανάπτυξης προγράµµατος Κατηγορίες γλωσσών προγραµµατισµού
3. Εκφράσεις και έλεγχος ροής
3. Εκφράσεις και έλεγχος ροής Τελειώνοντας αυτό το κεφάλαιο θα μπορείτε: Να διακρίνετε ανάμεσα σε μεταβλητές μέλη και αυτόματες μεταβλητές Να περιγράφετε την αρχικοποίηση των μεταβλητών μελών Να αναγνωρίζετε
Μεταγλωττιστές. Σημασιολογική Ανάλυση. Εργαστήριο 9. Διδάσκοντες: Δρ. Γεώργιος Δημητρίου Δρ. Άχμεντ Μάχντι
Μεταγλωττιστές Εργαστήριο 9 Σημασιολογική Ανάλυση Διδάσκοντες: Δρ. Γεώργιος Δημητρίου Δρ. Άχμεντ Μάχντι 2016-2017 Σύνταξη και Σημασιολογία Σε οποιαδήποτε γλώσσα (προγραμματισμού ή μη) υπάρχουν δύο βασικές
1.1 A. ΟΙ ΠΡΑΓΜΑΤΙΚΟΙ ΑΡΙΘΜΟΙ ΚΑΙ ΟΙ
. A. ΟΙ ΠΡΑΓΜΑΤΙΚΟΙ ΑΡΙΘΜΟΙ ΚΑΙ ΟΙ ΠΡΑΞΕΙΣ ΤΟΥΣ ΘΕΩΡΙΑ. Τα σύνολα των αριθµών Το σύνολο των φυσικών αριθµών. Το σύνολο των ακεραίων αριθµών. N {0,,, 3 } Z { 3,,, 0,,, 3 } Το σύνολο των ρητών αριθµών. Q
if(συνθήκη) {... // οµάδα εντολών } C: Από τη Θεωρία στην Εφαρµογή 5 ο Κεφάλαιο
C: Από τη Θεωρία στην Εφαρµογή Κεφάλαιο 5 ο Έλεγχος Προγράµµατος Γ. Σ. Τσελίκης Ν. Δ. Τσελίκας Η εντολή if (Ι) Η εντολή if είναι µία από τις βασικότερες δοµές ελέγχου ροής στη C, αλλά και στις περισσότερες
- Αναπαράσταση ακέραιας τιµής : - Εύρος ακεραίων : - Ακέραιοι τύποι: - Πράξεις µε ακεραίους (DIV - MOD)
Η Γλώσσα Pascal Χαρακτηριστικά Τύποι Δεδοµένων Δοµή προγράµµατος 1. Βασικές έννοιες Χαρακτηριστικά της γλώσσας Pascal Γλώσσα προγραµµατισµού Συντακτικό Σηµασιολογία Αλφάβητο της γλώσσας Pascal (Σύνολο
ΚΕΦΑΛΑΙΟ 8 Η ΓΛΩΣΣΑ PASCAL
8.1. Εισαγωγή ΚΕΦΑΛΑΙΟ 8 Η ΓΛΩΣΣΑ PACAL Πως προέκυψε η γλώσσα προγραμματισμού Pascal και ποια είναι τα γενικά της χαρακτηριστικά; Σχεδιάστηκε από τον Ελβετό επιστήμονα της Πληροφορικής Nicklaus Wirth to
Μεταγλωττιστές. Ενότητα 7: Συντακτική ανάλυση (Μέρος 1 ο ) Αγγελική Σγώρα Τμήμα Μηχανικών Πληροφορικής ΤΕ
Μεταγλωττιστές Ενότητα 7: Συντακτική ανάλυση (Μέρος 1 ο ) Αγγελική Σγώρα Τμήμα Μηχανικών Πληροφορικής ΤΕ Άδειες Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται σε άδειες χρήσης Creative Commons. Για εκπαιδευτικό
Γλώσσες Προγραμματισμού Μεταγλωττιστές. Συντακτική Ανάλυση με το Εργαλείο BISON
Γλώσσες Προγραμματισμού Μεταγλωττιστές Συντακτική Ανάλυση με το Εργαλείο BISON Πανεπιστήμιο Μακεδονίας Τμήμα Εφαρμοσμένης Πληροφορικής Ηλίας Σακελλαρίου Δομή Γεννήτριες Συντακτικών Αναλυτών Bison/yacc
ΕΡΓΑΣΤΗΡΙΟ 2 ΕΙΣΑΓΩΓΗ ΣΤΗ C. Εργαστήριο 2. Τµήµα Πληροφορικής και Τηλεπικοινωνιών
ΕΡΓΑΣΤΗΡΙΟ 2 ΕΙΣΑΓΩΓΗ ΣΤΗ C Εργαστήριο 2 Τµήµα Πληροφορικής και Τηλεπικοινωνιών οµή προγράµµατος Οδηγίες προεπεξεργαστή #include... # define... τµήµα δηλώσεων ηλωσεις και ορισµοί µεταβλητών. ηλωσεις συναρτήσεων
Visual Basic Βασικές Έννοιες
Visual Basi Βασικές Έννοιες «Είδα στον ύπνο µου ότι η ζωή είναι χαρά. Ξύπνησα και είδα ότι είναι χρέος. Αγωνίστηκα και είδα ότι τo χρέος είναι χαρά.» Ραµπριτανάθ Ταγκόρ Κουλλάς Χρίστος www.oullas.om oullas
ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ ΤΜΗΜΑ ΕΠΙΣΤΗΜΗΣ ΥΠΟΛΟΓΙΣΤΩΝ ΓΛΩΣΣΕΣ ΚΑΙ ΜΕΤΑΦΡΑΣΤΕΣ ΗΥ340
ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ ΤΜΗΜΑ ΕΠΙΣΤΗΜΗΣ ΥΠΟΛΟΓΙΣΤΩΝ ΓΛΩΣΣΕΣ ΚΑΙ ΜΕΤΑΦΡΑΣΤΕΣ ΗΥ340 ΕΑΡΙΝΟ ΕΞΑΜΗΝΟ 2010 Ι ΑΣΚΩΝ: ΑΝΤΩΝΙΟΣ ΣΑΒΒΙ ΗΣ ΒΑΣΙΚΗ ΕΡΓΑΣΙΑ ΦΑΣΗ 2η από 5 Ανάθεση: Πέµπτη 15 Απριλίου 2010, 11:00 (πρωί)
Κεφάλαιο 5ο: Εντολές Επανάληψης
Χρήστος Τσαγγάρης ΕΕ ΙΠ Τµήµατος Μαθηµατικών, Πανεπιστηµίου Αιγαίου Κεφάλαιο 5ο: Εντολές Επανάληψης Η διαδικασία της επανάληψης είναι ιδιαίτερη συχνή, αφού πλήθος προβληµάτων µπορούν να επιλυθούν µε κατάλληλες
ΔΟΜΗΜΕΝΟΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Κεφάλαιο 8 : H γλώσσα προγραµµατισµού Pascal 1 ο Μέρος σηµειώσεων (Ενότητες 8.1 & 8.2 σχολικού βιβλίου)
ΔΟΜΗΜΕΝΟΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Κεφάλαιο 8 : H γλώσσα προγραµµατισµού Pascal 1 ο Μέρος σηµειώσεων (Ενότητες 8.1 & 8.2 σχολικού βιβλίου) 1. Εισαγωγή Χαρακτηριστικά της γλώσσας Τύποι δεδοµένων Γλώσσα προγραµµατισµού
Κεφάλαιο 3 Η Σημασιολογία των Γλωσσών Προγραμματισμού
Κεφάλαιο 3 Η Σημασιολογία των Γλωσσών Προγραμματισμού Προπτυχιακό μάθημα Αρχές Γλωσσών Προγραμματισμού Π. Ροντογιάννης 1 Εισαγωγή Γνώση γλώσσας από τη σκοπιά Του συντακτικού (syntax) Περιγραφή με γραμματικές
Μεταγλωττιστές. Γιώργος Δημητρίου. Μάθημα 3 ο. Πανεπιστήμιο Θεσσαλίας - Τμήμα Πληροφορικής
Γιώργος Δημητρίου Μάθημα 3 ο Λεκτική Ανάλυση και Λεκτικοί Αναλυτές Γενικά για τη λεκτική ανάλυση Έννοιες που χρειαζόμαστε Τεχνικές λεκτικής ανάλυσης Πίνακας συμβόλων και διαχείριση λαθών Σχεδίαση λεκτικού
Σχεδίαση Γλωσσών Προγραμματισμού Λεξική Ανάλυση Ι. Εαρινό Εξάμηνο Lec 05 & & 26 /02/2019 Διδάσκων: Γεώργιος Χρ.
Σχεδίαση Γλωσσών Προγραμματισμού Λεξική Ανάλυση Ι Εαρινό Εξάμηνο 2018-2019 Lec 05 & 06 25 & 26 /02/2019 Διδάσκων: Γεώργιος Χρ. Μακρής Φάσεις μεταγλώττισης Αρχικό Πρόγραμμα Λεκτική Ανάλυση λεκτικές μονάδες
Μεταγλωττιστές. Δημήτρης Μιχαήλ. Ακ. Έτος Συντακτική Ανάλυση. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο
Μεταγλωττιστές Συντακτική Ανάλυση Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Ακ. Έτος 2011-2012 Συντακτική Ανάλυση Το συντακτικό μιας γλώσσας καθορίζει ποιες συμβολοσειρές
Παρουσίαση του εργαλείου BISON
Παρουσίαση του εργαλείου BISON Γεννήτρια Συντακτικών Αναλυτών Β Φάση Συντακτική Ανάλυση Χαρακτηριστικά του bison Γεννήτρια συντακτικών αναλυτών σε C/C++. Συµβατό µε το εργαλείο του Unixyacc. Σχετικά εύκολο
ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΕΠΙΣΤΗΜΗ ΤΩΝ ΥΠΟΛΟΓΙΣΤΩΝ. Λογισμικό Συστήματος. Κλειώ Σγουροπούλου
Λογισμικό Συστήματος Κλειώ Σγουροπούλου Λογισμικό συστήματος Λειτουργικό σύστημα Μεταφραστές γλώσσας (translators) Διερμηνείς (interpreters) Μεταγλωττιστές (compilers) Εκδότες (editors) Φορτωτές (loaders)
Διαδικασιακός Προγραμματισμός
Τμήμα ΜΗΧΑΝΙΚΩΝ ΠΛΗΡΟΦΟΡΙΚΗΣ ΤΕ ΤΕΙ ΔΥΤΙΚΗΣ ΕΛΛΑΔΑΣ Διαδικασιακός Προγραμματισμός Διάλεξη 4 η Τελεστές Οι διαλέξεις βασίζονται στο βιβλίο των Τσελίκη και Τσελίκα C: Από τη Θεωρία στην Εφαρμογή Σωτήρης
ιαφάνειες παρουσίασης #3
ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΗΛΕΚΤΡΟΝΙΚΩΝ ΥΠΟΛΟΓΙΣΤΩΝ http://www.corelab.ece.ntua.gr/courses/programming/ ιδάσκοντες: Στάθης Ζάχος (zachos@cs.ntua.gr) Νίκος Παπασπύρου (nickie@softlab.ntua.gr) ιαφάνειες παρουσίασης
for for for for( . */
Εισαγωγή Στον Προγραµµατισµό «C» Βρόχοι Επανάληψης Πανεπιστήµιο Πελοποννήσου Τµήµα Πληροφορικής & Τηλεπικοινωνιών Νικόλαος Δ. Τσελίκας Νικόλαος Προγραµµατισµός Δ. Τσελίκας Ι Ο βρόχος for Η εντολή for χρησιµοποιείται
Αρχές Γλωσσών Προγραμματισμού και Μεταφραστών: Εργαστηριακή Άσκηση
Αρχές Γλωσσών Προγραμματισμού και Μεταφραστών: Εργαστηριακή Άσκηση 2011-2012 Γιάννης Γαροφαλάκης, Καθηγητής Αθανάσιος Ν.Νικολακόπουλος, Υποψήφιος Διδάκτορας 28 Μαρτίου 2012 Περίληψη Σκοπός της παρούσας
Προγραμματισμός Ι (HY120)
Προγραμματισμός Ι (HY120) #6 εκτέλεση σε επανάληψη 1 Σπύρος Λάλης Εκτέλεση σε επανάληψη: while while () lexpr body true false Όσο η λογική συνθήκη επανάληψης lexpr αποτιμάται σε μια τιμή
Στόχοι και αντικείμενο ενότητας. Εκφράσεις. Η έννοια του τελεστή. #2.. Εισαγωγή στη C (Μέρος Δεύτερο) Η έννοια του Τελεστή
Στόχοι και αντικείμενο ενότητας Η έννοια του Τελεστή #2.. Εισαγωγή στη C (Μέρος Δεύτερο) Εκφράσεις Προτεραιότητα Προσεταιριστικότητα Χρήση παρενθέσεων Μετατροπές Τύπων Υπονοούμενες και ρητές μετατροπές
ΗΥ-150. Προγραµµατισµός. Εντολές Ελέγχου Ροής
ΗΥ-150 Εντολές Ελέγχου Ροής Σειριακή εκτέλεση εντολών Όλα τα προγράµµατα «γράφονται» χρησιµοποιώντας 3 είδη εντολών: Σειριακές εντολές (sequential built in C) Εντολές απόφασης (if, if/else, switch) Περιλαµβάνει
Κεφάλαιο 2: Τυπικές γλώσσες. Νίκος Παπασπύρου, Κωστής Σαγώνας Μεταγλωττιστές Μάρτιος / 216
Κεφάλαιο 2: Τυπικές γλώσσες Νίκος Παπασπύρου, Κωστής Σαγώνας Μεταγλωττιστές Μάρτιος 2017 13 / 216 Τυπικές γλώσσες (i) Βασικές έννοιες Αλφάβητο Σύμβολο Συμβολοσειρά Μήκος συμβολοσειράς Σύνολο συμβολοσειρών
Λειτουργικά. Συστήματα Ι. Φ ρ ο ν τ ι σ τ ή ρ ι ο. Αριστείδης Ηλίας. Εργαστήριο Ηλεκτρονικών Υπολογιστών
Λειτουργικά Αριστείδης Ηλίας Συστήματα Ι Φ ρ ο ν τ ι σ τ ή ρ ι ο Shell Scripting Εισαγωγή Ένα shell script είναι μια λίστα εντολών που εκτελούνται ακολουθιακά Εκτελούνται ανάλογα με το κέλυφος και για
ΚΕΦΑΛΑΙΟ 2 Βασικές έννοιες αλγορίθµων
ΚΕΦΑΛΑΙΟ 2 Βασικές έννοιες αλγορίθµων Αλγόριθµος : Είναι ένα σύνολο βηµάτων, αυστηρά καθορισµένων κι εκτελέσιµων σε πεπερασµένο χρόνο, που οδηγούν στην επίλυση ενός προβλήµατος. Χαρακτηριστικά ενός σωστού
Επαναληπτικό ιαγώνισµα Πληροφορικής Γ Γυµνασίου Γιώργος Λιακέας Σχολικός Σύµβουλος Πληροφορικής Ερωτήσεις
Επαναληπτικό ιαγώνισµα Πληροφορικής Γ Γυµνασίου (νέο βιβλίο Πληροφορικής Γυµνασίου Αράπογλου, Μαβόγλου, Οικονοµάκου, Φύτρου) Γιώργος Λιακέας Σχολικός Σύµβουλος Πληροφορικής Ερωτήσεις 1. Τι είναι ο Αλγόριθµος;
Γλώσσες Προγραμματισμού Μεταγλωττιστές
Γλώσσες Προγραμματισμού Μεταγλωττιστές Παραγωγή Ενδιάμεσου Κώδικα Πανεπιστήμιο Μακεδονίας Τμήμα Εφαρμοσμένης Πληροφορικής Ηλίας Σακελλαρίου Δομή Παραγωγή ενδιάμεσου κώδικα. Ενδιάμεσες γλώσσες. Αφηρημένα
Αυτόματα. Παράδειγμα: πωλητής καφέ (iii) Παράδειγμα: πωλητής καφέ (iv) Εισαγωγή στην Επιστήμη των Υπολογιστών 6
Εισαγωγή στην Επιστήμη των Υπολογιστών 3η ενότητα: Αυτόματα και Τυπικές Γραμματικές http://www.corelab.ece.ntua.gr/courses/ Αυτόματα Τρόπος κωδικοποίησης αλγορίθμων. Τρόπος περιγραφής συστημάτων πεπερασμένων
ΠΛΗ111. Ανοιξη Μάθηµα 4 ο. Στοίβα. Τµήµα Ηλεκτρονικών Μηχανικών και Μηχανικών Υπολογιστών Πολυτεχνείο Κρήτης
ΠΛΗ111 οµηµένος Προγραµµατισµός Ανοιξη 2005 Μάθηµα 4 ο Στοίβα Τµήµα Ηλεκτρονικών Μηχανικών και Μηχανικών Υπολογιστών Πολυτεχνείο Κρήτης Ανασκόπηση Αφηρηµένος Τύπος εδοµένων Στοίβα Υλοποίηση µε Πίνακα Υλοποίηση
ΠΑΝΕΠΙΣΤΗΜΙΟ AΙΓΑIΟΥ & ΑΕΙ ΠΕΙΡΑΙΑ Τ.Τ. Τμήματα Ναυτιλίας και Επιχειρηματικών Υπηρεσιών & Μηχ. Αυτοματισμού ΤΕ. Εισαγωγή στη Python
ΠΑΝΕΠΙΣΤΗΜΙΟ AΙΓΑIΟΥ & ΑΕΙ ΠΕΙΡΑΙΑ Τ.Τ. Τμήματα Ναυτιλίας και Επιχειρηματικών Υπηρεσιών & Μηχ. Αυτοματισμού ΤΕ ΠΛΗΡΟΦΟΡΙΚΗ ΤΕΧΝΟΛΟΓΙΑ ΚΑΙ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Η/Υ Εισαγωγή στη Python Νικόλαος Ζ. Ζάχαρης Αναπληρωτής
Θέματα Μεταγλωττιστών
Θέματα Μεταγλωττιστών Γιώργος Δημητρίου Ενότητα 1 η : Parsers Πανεπιστήμιο Θεσσαλίας - Τμήμα Ηλεκτρολόγων Μηχανικών & Μηχανικών Υπολογιστών Συντακτική Ανάλυση για ΓΧΣ Οι τεχνικές συντακτικής ανάλυσης κατηγοριοποιούνται
Δυναμικές Ιστοσελίδες Εισαγωγή στην Javascript για προγραμματισμό στην πλευρά του client
ΕΣΔ 516 Τεχνολογίες Διαδικτύου Δυναμικές Ιστοσελίδες Εισαγωγή στην Javascript για προγραμματισμό στην πλευρά του client Περιεχόμενα Περιεχόμενα Javascript και HTML Βασική σύνταξη Μεταβλητές Τελεστές Συναρτήσεις
Κατηγορικές Γραµµατικές
Κατηγορικές Γραµµατικές Γραµµατικές Χωρίς περιορισµούς Με συµφραζόµενα Χωρίς συµφραζόµενα Κανονικές Πεπερασµένων επιλογών Κατηγορικές Ενεργοποίησης Γραµµατικές G = { T, N, P, S } Τ: αλφάβητο τερµατικών
ΠΑΡΑΡΤΗΜΑ: QUIZ ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ
ΠΑΡΑΡΤΗΜΑ: QUIZ ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ (Οι ερωτήσεις µε κίτρινη υπογράµµιση είναι εκτός ύλης για φέτος) ΕΙΣΑΓΩΓΗ Q1. Οι Πρωταρχικοί τύποι (primitive types) στη Java 1. Είναι όλοι οι ακέραιοι και όλοι οι πραγµατικοί
Μέρος 2 Κατασκευή Συντακτικού Αναλυτή
Αντίρριο, 05/04/2017 Προδιαγραφές Εργαστηριακής Εργασίας για το μάθημα «Μεταγλωττιστές» To δεύτερο μέρος της εργασίας έχει ως στόχο την ανάπτυξη του συντακτικού αναλυτή με χρήση του bison / byacc. Στο
Θέματα Μεταγλωττιστών
Γιώργος Δημητρίου Ενότητα 1 η : Parsers Συντακτική Ανάλυση για ΓΧΣ Οι τεχνικές συντακτικής ανάλυσης κατηγοριοποιούνται με βάση διάφορα κριτήρια: Κατεύθυνση ανάλυσης μη τερματικών συμβόλων Σειρά επιλογής
Η γλώσσα προγραμματισμού EEL
Προγραμματιστική άσκηση: Η γλώσσα προγραμματισμού EEL Η EEL (Early Experimental Language) είναι μια μικρή γλώσσα προγραμματισμού. Παρόλο που οι προγραμματιστικές της ικανότητες είναι μικρές, η εκπαιδευτική
Εισαγωγή στον Προγραμματισμό
Εισαγωγή στον Προγραμματισμό Αριθμητική Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Ακ. Έτος 2012-2013 Δεύτερο Πρόγραμμα 1 / * Second Simple Program : add 2 numbers * / 2
Κεφάλαιο 6 Υλοποίηση Γλωσσών Προγραμματισμού
Κεφάλαιο 6 Υλοποίηση Γλωσσών Προγραμματισμού Προπτυχιακό μάθημα Αρχές Γλωσσών Προγραμματισμού Π. Ροντογιάννης 1 Μεταγλωττιστής Πρόγραμμα Διαβάζει προγράμματα δεδομένης γλώσσας (πηγαία γλώσσα) και τα μετατρέπει
ΣΕΤ ΑΣΚΗΣΕΩΝ 4. Προθεσµία: 8/1/12, 22:00
ΣΕΤ ΑΣΚΗΣΕΩΝ 4 ΕΡΓΑΣΤΗΡΙΟ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ I, ΑΚΑΔΗΜΑΪΚΟ ΕΤΟΣ 2011-2012 Προθεσµία: 8/1/12, 22:00 Περιεχόµενα Διαβάστε πριν ξεκινήσετε Εκφώνηση άσκησης Οδηγίες αποστολής άσκησης Πριν ξεκινήσετε (ΔΙΑΒΑΣΤΕ
Στοιχειώδης προγραμματισμός σε C++
Στοιχειώδης προγραμματισμός σε C++ Σύντομο Ιστορικό. Το πρόγραμμα Hello World. Ο τελεστής εξόδου. Μεταβλητές και δηλώσεις τους. Αντικείμενα, μεταβλητές, σταθερές. Ο τελεστής εισόδου. Θεμελιώδεις τύποι.
Απάντηση: (func endfunc)-([a-za-z])+
Γλώσσες Προγραμματισμού Μεταγλωττιστές Ασκήσεις Επανάληψης ) Περιγράψτε τις κανονικές εκφράσεις που υποστηρίζουν (i) συμβολοσειρές που ξεκινούν με το πρόθεμα "func" ή "endfunc" ακολουθούμενο το σύμβολο
Κεφάλαιο 4 Σημασιολογία μιας Απλής Προστακτικής Γλώσσας
Κεφάλαιο 4 Σημασιολογία μιας Απλής Προστακτικής Γλώσσας Προπτυχιακό μάθημα Αρχές Γλωσσών Προγραμματισμού Π. Ροντογιάννης 1 Εισαγωγή - 1 Μία κλασσική γλώσσα προγραμματισμού αποτελείται από: Εκφράσεις (των
ΕισαγωγήστουςΗ/Υ. PHP Hypertext Preprocessor
ΕισαγωγήστουςΗ/Υ PHP Hypertext Preprocessor ΤιείναιηPHP; PHP είναιµία server-based scripting language σχεδιασµένη ειδικά για το web. Σε µία html σελίδα µπορούµε να ενσωµατώσουµε php κώδικα που εκτελείται
Μεταγλωττιστές. Ενότητα 2: Τυπικές γλώσσες (Μέρος 1 ο ) Αγγελική Σγώρα Τμήμα Μηχανικών Πληροφορικής ΤΕ
Μεταγλωττιστές Ενότητα 2: Τυπικές γλώσσες (Μέρος 1 ο ) Αγγελική Σγώρα Τμήμα Μηχανικών Πληροφορικής ΤΕ Άδειες Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται σε άδειες χρήσης Creative Commons. Για εκπαιδευτικό
Εισαγωγή στην Επιστήμη των Υπολογιστών
Εισαγωγή στην Επιστήμη των Υπολογιστών 3η ενότητα: Αυτόματα και Τυπικές Γραμματικές http://www.corelab.ece.ntua.gr/courses/ Αυτόματα Τρόπος κωδικοποίησης αλγορίθμων. Τρόπος περιγραφής συστημάτων πεπερασμένων
Ανάπτυξη Μεγάλων Εφαρµογών στη Γλώσσα C (2)
Ανάπτυξη Μεγάλων Εφαρµογών στη Γλώσσα C (2) Στην ενότητα αυτή θα µελετηθούν τα εξής επιµέρους θέµατα: Οργάνωση Προγράµµατος Header Files Μετάφραση και σύνδεση αρχείων προγράµµατος ΕΠΛ 132 Αρχές Προγραµµατισµού
Σύντομες εισαγωγικές σημειώσεις για την. Matlab
Σύντομες εισαγωγικές σημειώσεις για την Matlab Δήλωση Μεταβλητών Για να εισάγει κανείς δεδομένα στη Matlab υπάρχουν πολλοί τρόποι. Ο πιο απλός είναι στη γραμμή εντολών να εισάγουμε αυτό που θέλουμε και
Δομημένος Προγραμματισμός (ΤΛ1006)
Τεχνολογικό Εκπαιδευτικό Ίδρυμα Κρήτης Σχολή Εφαρμοσμένων Επιστημών Τμήμα Ηλεκτρονικών Μηχανικών Τομέας Αυτοματισμού και Πληροφορικής Δομημένος Προγραμματισμός (ΤΛ1006) Δρ. Μηχ. Νικόλαος Πετράκης, Καθηγητής
ιαφάνειες παρουσίασης #4
ΕΙΣΑΓΩΓΗ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ http://www.corelab.ece.ntua.gr/courses/programming/ ιδάσκοντες: Στάθης Ζάχος (zachos@cs.ntua.gr) Νίκος Παπασπύρου (nickie@softlab.ntua.gr) ιαφάνειες παρουσίασης #4!Λοιπές εντολές!