Διάλεξη 02: Αντικειμενοστρεφής Προγραμματισμός με την JAVA. Διδάσκων: Παναγιώτης Ανδρέου

Μέγεθος: px
Εμφάνιση ξεκινά από τη σελίδα:

Download "Διάλεξη 02: Αντικειμενοστρεφής Προγραμματισμός με την JAVA. Διδάσκων: Παναγιώτης Ανδρέου"

Transcript

1 Διάλεξη 02: Αντικειμενοστρεφής Προγραμματισμός με την JAVA Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Εισαγωγή στις έννοιες: - Επισκόπηση της JAVA - Περισσότερες Πληροφορίες στο μάθημα ΕΠΛ233 Διδάσκων: Παναγιώτης Ανδρέου ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 1

2 Προγράμματα Τα προγράμματα (software), είναι βασικά ένα σύνολο από οδηγίες στον υπολογιστή. Χωρίς τα προγράμματα ο υπολογιστής είναι μία άδεια μηχανή. Δεδομένου ότι ο υπολογιστής δεν καταλαβαίνει την φυσική γλώσσα αλλά μόνο την γλώσσα μηχανής (machine language), χρειαζόμαστε κάποιες ειδικές γλώσσες (γλώσσες προγραμματισμού) για να επικοινωνήσουμε μαζί του. Παραδείγματα γλωσσών προγραμματισμού: C, C++, JAVA, C#, Visual Basic, Fortran, κ.τ.λ. ΠΑΡΑΔΕΙΓΜΑ ΠΡΟΓΡΑΜΜΑΤΟΣ σε JAVA public class HelloWorld{ public static void main(string[] args){ System.out.println("Hello World!!!"); ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 2

3 Η πλατφόρμα της JAVA Πλατφόρμα: Περιβάλλον λογισμικού και υλικού στο οποίο εκτελείται ένα πρόγραμμα. Συνήθως είναι συνδυασμός του Λειτουργικού Συστήματος και του Υλικού Υποστρώματος του ΛΣ. Δημοφιλείς πλατφόρμες: Microsoft Windows, Linux, SolarisOS, MacOS. Πλατφόρμα Java: Σύστημα λογισμικού που τρέχει πάνω σε διάφορες πλατφόρμες υλικού. Αποτελείται από: Την Εικονική Μηχανή JAVA: Java Virtual Machine Την Προγραμματιστική Διαπροσωπεία Εφαρμογών της JAVA (Java Application Programming Interface- API) Περιβάλλον Μεταγλώττισης Πλατφόρµα JAVA Πηγαίος Κώδικας(.java) Compiler (javac.exe) Java Bytecode(.class) Class loader and Bytecode verifier Java Class Library The Java Virtual Machine Java Interpreter (java.exe) Run Time System Just-in-time compiler Operating System Hardware ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 3

4 Τυπικός Κύκλος Ζωής ενός Προγράμματος JAVA Αρχείο HelloWorld.java ΠΑΡΑΔΕΙΓΜΑ ΠΗΓΑΙΟΥ ΚΩΔΙΚΑ public class HelloWorld{ public static void main(string[] args){ System.out.println("Hello World!!!"); Μεταγλώττιση (javac) javac HelloWorld.java Αρχείο HelloWorld.class ΠΑΡΑΔΕΙΓΜΑ BYTE CODE Method HelloWorld() 0 aload_0 Method void main(java.lang.string[]){ 0 getstatic #2 3 ldc #3 < String "Hello World!!!" > 5 invokevirtual #4 ιερµηνεία και Εκτέλεση (java) java HelloWorld Δημιουργία/Ενημέρωση Πηγαίου Κώδικα Πηγαίος Κώδικας (Αποθήκευση στον δίσκο) Μεταγλώττιση Πηγαίου Κώδικα ByteCode (Αποθήκευση στον δίσκο) Εκτέλεση Bytecode Αποτέλεσμα Σε περίπτωση προβλημάτων μεταγλώττισης Σε περίπτωση λάθος αποτελέσματος ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 4

5 Ενσωματωμένο Περιβάλλον Ανάπτυξης(IDE) Ένα Ενσωματωμένο Περιβάλλον Ανάπτυξης (Integrated Development Environment (IDE)) συνήθως περιλαμβάνει: Ένα συντάκτη πηγαίου κώδικα (π.χ., Notepad) Εργαλεία αυτοματοποίησης (π.χ., αυτόματη μεταγλώττιση κώδικά, παρουσίαση συντακτικών λαθών) Ένα ελεγκτή/παρατηρητή (debugger) Παράδειγμα Eclipse IDE ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 5

6 Παραδείγματα: Κλάση class Circle { //Η ακτίνα αυτού του κύκλου double radius = 1.0; //Δημιούργησε ένα αντικείμενο τύπου κύκλος Circle () { ; //Δημιούργησε ένα αντικείμενο τύπου κύκλος //με συγκεκριμένη ακτίνα Circle (double newradius) { radius = newradius; ; //Επέστρεψε το εμβαδό αυτόυ του κύκλου double getarea () { return radius * radius * π; Δεδομένα/ Μεταβλητές Κατασκευαστές Μέθοδοι ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 6

7 Παραδείγματα: Αντικείμενα Κλάση Circle Κλάση Test: περιλαμβάνει την μέθοδο main public class Test{ public static void main(string[] args){ Circle a = new Circle(); Circle b = new Circle(5); Circle c = new Circle(20); 3 αντικείμενα a b c της κλάσης Circle object Circle radius = 1.0 object Circle radius = 5.0 object Circle radius = 20.0 ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 7

8 Απλό if else Θυμηθείτε το πρόγραμμα για τη δημιουργία κύκλων με ακτίνα Πρόβλημα:Τι γίνεται αν δώσουμε αρνητική τιμή για την ακτίνα του κύκλου; λάθος αποτέλεσμα Λύση:Μόνο αν ο χρήστης δώσει θετική τιμή τότε αλλάζουμε την τιμή της radius Σύνταξη απλού if: if (<booleanexpression> ){ else { class Circle { double radius = 1.0; Circle (double newradius) { radius = newradius; ; class Circle { double radius = 1.0; Circle (double newradius) { if ( newradius >= 0 ){ radius = newradius; else { radius = 0; ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 8

9 if else if else Τι συμβαίνει αν υπάρχουν πολλές συνθήκες για την ίδια μεταβλητή; Παράδειγμα: Υπάρχουν οι ακόλουθοι φόροι σύμφωνα με τον μισθό κάποιου ατόμου: μισθός <=20,000 0% φόρος μισθός >20,000 και <=30,000 20% φόρος μισθός >30,000 και <=40,000 30% φόρος μισθός >40,000 40% φόρος Πρόβλημα: Χρειάζεται να γράψουμε 3x if statements; ΌΧΙ Λύση:Χρήση του if else if else computetax (double salary) { double tax = 0.0; if ( salary <= ) { tax = 0.0; else if ( salary > && salary <= 30000) { tax = 0.2; else if ( salary > && salary <= 40000) { tax = 0.3; else { tax = 0.4; return tax * salary; Λογικός Τελεστής ΚΑΙ (&&) (στις επόμενες διαφάνειες) ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 9

10 switch case To switch ομαδοποιεί πολλά if Σύνταξη: Μεταβλητές τύπου char, byte, short, int Μεταβλητές ίδιου τύπου με <switch-expression> To break σταματάει την εκτέλεση. Αν δεν υπάρχει break τότε η εκτέλεσειθα συνεχιστεί στο επόμενο case Όταν κανένα case δεν ικανοποιηθεί τότε εκτελούντεοι δηλώσεις του default switch ( <switch-expression> ) { case value1: statement(s)1; break; case value2: statement(s)2; break; case valuen: statement(s)n; break; default: statement(s)-for-default; ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 10

11 O τριαδικός τελεστής συνθήκης (ternary operator) Η ακόλουθη δήλωση if (x > 0) y = 1; else y = -1; είναι ισοδύναμη με y = (x > 0)? 1 : -1; Σύνταξη Τριαδικού Τελεστή: (<boolean-exp> )? exp1 : exp2; Παραδείγματα System.out.println( ( num % 2 == 0 )? //(boolean-exp) num + is even : //exp1 num + is odd ); //exp2 ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 11

12 Προγραμματισμός με βρόγχους (loops) 3 είδη δηλώσεων προγραμματισμού με βρόγχους while while ( <boolean expression> ) { //δηλώσεις do while do { //δηλώσεις while ( <boolean expression> ); for for( <initial actions>; <boolean expr.>; actions after step ) //δηλώσεις Όλα τα είδη βρόγχων είναι ισοδύναμα. ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 12

13 Παραδείγματα προγραμματισμού με βρόγχους Παράδειγμα <while> int i = 0; while (i < 10) { System.out.println( "while"); i ++; while for Παράδειγμα <for> for ( int i=0; i<10; i++) { System.out.println( "for"); dowhile Παράδειγμα <do-while> int i = 0; do { System.out.println( "do-while"); i++; while (i < 10); ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 13

14 Μέθοδοι (methods) Μέθοδος:μία συλλογή από ομαδοποιημένες δηλώσεις οι οποίες εκτελούν κάποια (ες) λειτουργία (ες). Η υπογραφή μίας μεθόδουαποτελείται από το όνομά τηςκαι τη λίστα με της παραμέτρους που δέχεται. Σύνταξη: modifiers return value type method name parameter list public static int max( int num1, int num2 ) { int result = num1; if ( num2 > num1 ) { result = num2; return result; method signature method body return value ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 14

15 Πέρασμα Παραμέτρων Πέρασμα διά τιμής:οι τιμές των μεταβλητών αντιγράφονται στις παραμέτρους της μεθόδου ==> οι αρχικές μεταβλητές δεν αλλάζουν Πέρασμα διά αναφοράς: δεν υπάρχει! Παράδειγμα public class Increment { public static void main( String[] args ) { int x = 1; System.out.println( "before the call, x is " + x); increment(x); System.out.println( "after the call, x is " + x); public static void increment( int n ) { n++; System.out.println( "n inside the method is " + n); 1. x=1 2. x=1 3. x=1copy to n 7. x=1 4. n=1 5. n=2 6. n=2 ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 15

16 Πίνακες Πίνακας:μία δομή δεδομένων που αντιπροσωπεύει μία συλλογή με στοιχεία του ίδιου τύπου. Οι πίνακες στην JAVA έχουν σχεδιαστεί κατά τρόπον ώστε να ξεπερνιούνται οι δυσκολίες του προγραμματισμού πινάκων της C/C++. Στη JAVA είναι εξασφαλισμένο ότι ένας πίνακας θα αρχικοποιηθεί και ότι δεν θα επισυμβεί πρόσβαση εκτός των ορίων του. Τα χαρακτηριστικά αυτά υλοποιούνται με κάποιο σχετικό κόστος μνήμης και χρόνου εκτέλεσης (κατά την εκτέλεση γίνεται έλεγχος κατά πόσο δεν γίνεται υπέρβαση των ορίων του πίνακα). Κατά τη δημιουργία ενός πίνακα, κατ ουσίανδημιουργείται ένας πίνακας χειριστηρίων (Handles), τα οποία αρχικοποιούνται σε null. Είναι ευθύνη του προγραμματιστή να αρχικοποιήσει σωστά τα χειριστήρια, ώστε να παραπέμπουν σε αντικείμενα. ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 16

17 Πίνακες (συν.) Παράδειγμα αναπαράστασης πίνακα: int[] x = new int[5]; x Μεταβλητή αναφοράς αναφορά µνήµης στοιχείο στη θέση 2 x[0] x[1] x[2] x[3] x[4] τιµή πεδίου Πρόσβαση σε κάθε στοιχείο του πίνακα με το ευρετήριο του. π.χ., το στοιχείο στη θέση 2 = x[2]. Ιδιότητα (property) <length>: Επιστρέφει το μέγεθος του πίνακα. π.χ., x.length= 5 ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 17

18 Παραδείγματα χρήσης πίνακα Τύπωμα των στοιχείων ενός πίνακα int[] x = new int[5];... for(int i=0; i<x.length; i++) { System.out.println( x[i] ); Πρόσθεση των στοιχείων ενός πίνακα int[] x = new int[5]; int sum=0;... for(int i=0; i<x.length; i++) { sum = sum + x[i]; ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 18

19 Πολυδιάστατοι πίνακες Σύνταξη: <τύπος δεδομένων>[ ][ ]... <όνομα πίνακα>, π.χ., int[][] x Δήλωση Πινάκων int[][] x; //Δήλωση πίνακα 2D με ακέραιους char[][][] a; //Δήλωση πίνακα 3D με χαρακτήρες Αρχικοποίηση Πινάκων Η αρχικοποίηση μπορεί να γίνει με τηδήλωση new x = new int[2][3]; //Δημιουργία πίνακα με 2 γραμμές και 3 στήλες ή μπορεί να γίνει με την αυτόματη ανάθεση στοιχείων x = { {1, 2, 3, {4, 5, 6 ; μόνο κατά την δήλωση! Δήλωση και Αρχικοποίηση σε ένα Βήμα int[][] x= new int[2][3]; ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 19

20 Συλλογές (collections) Οι συλλογές (collections)είναι δομές παρόμοιες με πίνακες (arrays) τις εξής διαφορές: Το μέγεθος του μεταβάλλεται δυναμικά Οποιοδήποτε είδος αντικειμένου μπορεί να εισαχθεί σε μία συλλογή ΔΕΝ υποστηρίζουν εισαγωγή αρχέγονων τύπων (π.χ., int). Παραδείγματα συλλογών: Vector, BitSet, HashTable, Stack ArrayList: πολυχρησιμοποιημένη δομή (παρόμοια με Vector) Δεν είναι συγχρονισμένη, αντίθετα με vector Όταν αυξάνει δυναμικά το μέγεθος κατά το μισό του υπάρχον μέγεθος (ο vector αυξάνει κατά το διπλάσιο) Είναι πιο γρήγορη λόγω του ότι δεν είναι συγχρονισμένη ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 20

21 Boxing Οι συλλογές ΔΕΝ δέχονται πρωτόγονους τύπους αλλά μόνο δείκτες σε αντικείμενα (reference types). Ερώτηση: Τι γίνεται όταν χρειαζόμαστε πρωτόγονους τύπους; Απάντηση: Boxing Ορισμοί: Box Ένα στιγμιότυπο μίας κλάσης περιτυλίγματος (wrapper) η οποία αποθηκεύει την τιμή ενός πρωτόγονου τύπου. Boxing Δημιουργία ενός box για μία τιμή πρωτόγονος τύπου Unboxing Επιστροφή της τιμής πρωτόγονου τύπου από το box ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 21

22 Manual/Auto boxing and unboxing Οι αρχέγονοι τύποι δεν µπορούν να χρησιµοποιηθούν στις περισσότερες περιπτώσεις -you need a wrapper myvector.add(new Integer(5)); Αντίστοιχα δεν επιτρέπεται να χρησιµοποιηθεί ένα αντικείµενο εκεί που χρειάζεται αρχέγονος τύπος. --you need to unwrap it int n = ((Integer)myVector.lastElement()).intValue(); Integer inumber = new Integer(10); Integer inumber= 10; inumber= new Integer( inumber.intvalue()++ ); inumber++; Manual boxing Auto-boxing Manual unboxing Auto-unboxing ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 22

23 Κληρονομικότητα Δύο βασικές έννοιες: Ένα είδος σχέσης Ένας προγραμματιστικός μηχανισμός για επαναχρησιμοποίηση ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 23

24 Προγραμματιστικός Μηχανισμός Κληρονομικότητας Μία κλάση μπορεί να κληρονομήσει όλα τα επιτρεπτά στοιχεία (πεδία και μεθόδους) από τον πατέρα της από τον πατέρα του πατέρα της, κτλ. Μία υποκλάση μπορεί να προσθέσει καινούρια πεδία Μία υποκλάση μπορεί να προσθέσει καινούριες μεθόδους Μία υποκλάση μπορεί να επεκτείνει υφιστάμενες μεθόδους (overloading) Μία υποκλάση μπορεί να επανακαθορίσει υφιστάμενες μεθόδους (overriding) ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 24

25 Υποκλάσεις και Υπερκλάσεις Generalize Υπερκλάση Circle Circle Data Circle Methods Υποκλάση Cylinder Circle Data Cylinder Data Circle Methods Cylinder Methods Specialize ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 25

26 Υποκλάσεις και Υπερκλάσεις(συν.) class Circle { // Η ακτίνα αυτού του κύκλου private double radius; // Δημιούργησε ένα κύκλο public Circle () {radius = 1.0; // Δημιούργησε ένα κύκλο // συγκεκριμένη ακτίνα public Circle(double newradius) { radius = newradius; // Επέστρεψε την ακτίνα public double getradius() { return radius; // Επέστρεψε το εμβαδό public double getarea() { return radius * radius * π; class Cylinder extends Circle { // Το μήκος αυτού του κύλινδρου private double length; // Δημιούργησε ένα κύλινδρο public Cylinder() { super(); this.length= 1.0; // Δημιούργησε ένα κύλινδρο με // συγκεκριμένο μήκος public Cylinder(int length) { this.length= length; // Επέστρεψε το μήκος public double getlength() { return length; // Επέστρεψε τον όγκο // αυτού του κύλινδρου public double getvolume () { return getarea() * length; ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 26

27 Χειριστήριο Υπερκλάσης (super) Η λέξη κλειδί super αναφέρεται στην υπερκλάση Μπορεί να χρησιμοποιηθεί με δύο τρόπους: Για το κάλεσμα του constructor της υπερκλάσης Για το κάλεσμα μία μεθόδου της υπερκλάσης Στην περίπτωση που καλείται ο constructor της κλάσης τότε πρέπει να είναι η πρώτη δήλωση στον κώδικα. Σημείωση:Η λέξη κλειδίthisαναφέρεται στην υποκλάση και είναι ένα χειριστήριο προς το ίδιο το αντικείμενο. ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 27

28 Απόκρυψη Ονομάτων (Name Hiding) Πεδία Μέσα σε μία κλάση, κάθε πεδίο πρέπει να έχει μοναδικό όνομα Μέσα από την κληρονομικότητα προκύπτουν περιπτώσεις που ένα πεδίο στην υποκλάση μπορεί να έχει το ίδιο όνομα με ένα πεδίο στην υπερκλάση Σε αυτή την περίπτωση, το πεδίο στην υποκλάση κρύβει/επισκιάζει (hides) το πεδίο στην υπερκλάση Για να έχουμε πρόσβαση στο πεδίο της υπερκλάσης πρέπει να χρησιμοποιήσουμε την λέξι κλειδί super Μεθόδοι Παρόμοια υπάρχει περίπτωση μία μέθοδος στην υποκλάση να έχει την ίδια υπογραφή με μία μέθοδο της υπερκλάσης Σε αυτή την περίπτωση, η μέθοδος της υποκλάσης υπερσκελίζει (overrides) την μέθοδο της υπερκλάσης ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 28

29 Παράδειγμα Υπερσκέλισης(Overriding) public class Circle extends GeometricObject { // Other methods are omitted /** Override the tostring method defined in GeometricObject */ public String tostring() { return super.tostring() + "\nradius is " + radius; ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 29

30 Αφαιρετικές (abstract) κλάσεις και μεθόδοι Μία αφαιρετική κλάση - abstract class Δεν μπορεί να αρχικοποιηθεί αντικείμενο της κλάσης Πρέπει να επεκταθεί(κληρονομικότητα) και να υλοποιηθεί από τις υποκλάσεις Μία αφαιρετική μέθοδος - abstract method Η υπογραφή μίας μεθόδου χωρίς υλοποίηση ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 30

31 Παράδειγμα: Αφαιρετικές Κλάσεις και Μέθοδοι Abstract Class Οι abstract µεθόδοι είναι µε italics Οι abstract µεθόδοι getarea και getperimeterγίνονται ovverrideστις κλάσεις Circle και Rectangle ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 31

32 Αφαιρετικές Μεθόδοι H Javaμας επιτρέπει να δηλώνουμε ρητά(explicit) ορισμένες μεθόδους μιας κλάσης σαν αφαιρετικές ώστε: Να έχουμε τη δυνατότητα να προσδιορίζουμε την διεπαφή της κλάσης που τις περιέχει. Να αποτρέπεται η εκ παραδρομής κλήση τους από άλλες μεθόδους. Ο προσδιορισμός μιας μεθόδου ως αφαιρετικής γίνεται ως εξής: abstract void X(); Τα abstract methods μπορούν να υπάρχουν μόνο σε abstract classes ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 32

33 Αφαιρετικές κλάσεις Μια κλάση η οποία περιλαμβάνει έστω και μια «αφαιρετική» μέθοδο, καθίσταται επίσης αφαιρετική και πρέπει να δηλωθεί ως αφαιρετική. Όταν μία κλάση κληρονομεί από μια αφαιρετική κλάση θα πρέπει να υλοποιήσουμε όλες τις αφαιρετικές μεθόδους της υπερκλάσης. Διαφορετικά ο μεταφραστής επιβάλλει να προσδιορίσουμε την κλάση μας σαν αφαιρετική. Μπορούμε τέλος να δηλώσουμε μια κλάση σαν αφαιρετική, χωρίς ωστόσο η κλάση αυτή να περικλείει αφαιρετικές μεθόδους. Γιατί να θέλουμε κάτι τέτοιο; Για να αποκλείσουμε τη δημιουργία αντικειμένων αυτής της κλάσης. ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 33

34 Διαπροσωπείες (Interfaces) Μία διαπροσωπεία (interface)είναι μία δομή (παρόμοια με την κλάση) ή οποία περιέχει: Δηλώσεις μεθόδων και όχι καθορισμό τους (εμμέσως είναι abstract) Σταθερές (constant) μεταβλητές Καθορίζει την μορφή που πρέπει να υπάρχει σε μία κλάση, ένα συμβόλαιο το οποίο δηλώνει πως δουλεύει μία κλάση Δηλώνεται με την λέξη interface Οι Διαπροσωπείες είναι παρόμοιες με τις Αφαιρετικές κλάσεις, αλλά όχι οι ίδιες ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 34

35 Δήλωση Διαπροσωπείας (Interface Declaration) Σύνταξη δήλωσης διαπροσωπείας: public interface InterfaceName { //constant declarations //method signatures Παράδειγμα public interface Edible{ // Describe how to eat public String howtoeat(); ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 35

36 Σταθερές Μεταβλητές (Constant Variables) Παράδειγμα δήλωσης Σταθερών Μεταβλητών public interface InterfaceName { //constant declarations int x=1; double PI=3.1415; Το πιο πάνω είναι ισοδύναμο με το πιο κάτω public interface InterfaceName { //constant declarations public static final int x=1; public static final double PI=3.1415; Πρόσβαση με <διαπροσωπεία>.<μεταβλητή> π.χ., InterfaceName.x ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 36

37 Παράδειγμα Διαπροσωπείας 1 <<interface>> Animals Attributes Operations public String walk() Mammals Attributes Operations public String walk() { Birds Attributes Operations public String walk() { Fish Attributes Operations public String walk() { ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 37

38 Παράδειγμα Διαπροσωπείαςκαι Κληρονομικότητας <<interface>> IAnimals Attributes Operations public String eat() Mammals Attributes Operations public String eat() { Birds Attributes Operations public String eat() { Fish Attributes Operations public String eat() { Lion Attributes Operations public String eat() { Eagle Attributes Operations public String eat() { Shark Attributes Operations public String eat() { ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 38

39 Παράδειγμα Διαπροσωπείας και Κληρονομικότητας public interface IAnimals { abstract void eat(); String getname(); class Lion extends Mammals { public void eat() { public String getname() { class Mammals implements IAnimals { public void eat() { public String getname() { class Birds implements IAnimals { public void eat() { public String getname() { class Eagle extends Birds { public void eat() { public String getname() { class Shark extends Fish { public void eat() { public String getname() { class Fish implements IAnimals { public void eat() { public String getname() { ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 39

40 Σημαντικές διαπροσωπείες: Comparable Η διαπροσωπεία Comparable: χρησιμοποιείται για καθορισμό του πως γίνεται σύγκριση αντικειμένων (π.χ., String, Date) java.lang Interface Comparable int compareto(t o) Καθορίζει μία φυσική σειρά για τα αντικείμενα όπως ισχύει για αριθμητικά δεδομένα, π.χ., 1<2, ab < ac Περιλαμβάνει την μέθοδο compareto: Συγκρίνει το αντικείμενο this με το αντικείμενο που δίνεται σαν παράμετρος Ακολούθως συγκρίνουμε αντικείμενα σαν να είναι αριθμοί, π.χ., ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 40

41 Παράδειγμα Χρήσης Comparable class ComparableCircle extends Circle implements Comparable { public ComparableCircle(double radius) { super(radius); /** Implement the compareto method defined in Comparable */ public int compareto(object o) { if (getradius() > ((ComparableCircle) o).getradius()) return 1; else if (getradius() < ((ComparableCircle) o).getradius()) return -1; else return 0; ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 41

42 Πολυμορφισμός (polymorphism) Πολύ: πολλές, πολλαπλές, Μορφή: χαρακτήρας, εμφάνιση, απεικόνιση, Πολλαπλές μορφές Ο πολυμορφισμός είναι μία από τις πιο βασικές έννοιες του αντικειμενοστρεφή προγραμματισμού. Σχετίζεται με την αποσύνδεση των μεθόδων από τους τύπους ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 42

43 Είδη Πολυμορφισμού Υπερφόρτωση (Overloading) Μεθόδων (Method Overloading) Τελεστών (Operator Overloading (C++, C#)) Υπερσκέλιση Μεθόδων (Method Overriding) Δυναμική Πρόσδεση (Late (Dynamic) Binding) Upcasting/Downcasting ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 43

44 Παράδειγμα Method Overloading public static void method() { public static void method(int x) { public static void method(int x, String y) { Constructor Overloading class Circle { double radius; Circle () { this (1.0); Circle (double newradius) { radius = newradius; ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 44

45 Παράδειγμα Operator Overloading (C#) Υποθέστε κλάση MyObjμε μεταβλητές inta, intb public static MyObj operator + (MyObj x, MyObj y) { return new MyObj(x.a+y.a, x.b+y.b); public static MyObj operator == (MyObj x, MyObj y) { if (x.a == y.a && x.b == y.b) return true; return false; public static MyObj operator!= (MyObj x, MyObj y) { if (x.a!= y.a x.b!= y.b) return true; return false; ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 45

46 Υπερσκέλιση (Override) vs.υπερφόρτωση (Overload) Η Υπερφόρτωση (overload) μπορεί να πραγματοποιηθεί: είτε στην ίδια κλάση με ορισμό μεθόδων με το ίδιο όνομα ή μέσω κληρονομικότητας με ορισμό μεθόδων με το ίδιο όνομα Η Υπερσκέλιση (Overriding) μπορεί να συμβεί μόνο μέσω κληρονομικότητας Οι ακόλουθες δηλώσεις μεθόδων ΔΕΝ μπορούν υπερσκελιθούν: private static(εκτός και αν ) final ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 46

47 Πρόσδεση (Binding) Πρόσδεση (Binding) συμβαίνει όταν: Συνδέεται μία μεταβλητή με μία τιμή Συνδέεται το κάλεσμα μίας μεθόδου με υλοποίησή της Δύο είδη Πρόσδεσης Early (static) Binding:συμβαίνει πριν να τρέξει το πρόγραμμα από τον μεταγλωττιστή ή linker. H compilers της C υποστηρίζουν μόνο αυτό. Late (dynamic) Binding:συμβαίνει όταν η πρόσδεση γίνεται κατά τη διάρκεια εκτέλεσης του προγράμματος ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 47

48 Late (Dynamic) Binding Ο μεταγλωττιστής δεν γνωρίζει εκ των προτέρων ποιος τύπος θα χρησιμοποιηθεί Για να πραγματοποιηθεί το late binding πρέπει να υπάρχει κάποιος μηχανισμός που καθορίζει τον τύπου του αντικειμένου και την μέθοδο που πρέπει να καλεστεί την συγκεκριμένη στιγμή εκτέλεσης Η JAVA πραγματοποιεί όλα τα method bindings με late binding Εξαίρεση:αν οι μεθόδοι είναι δηλωμένες σαν static ή final Προσοχή:οι μεθόδοι που είναι δηλωμένες σαν private είναι εμμέσως final ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 48

49 Παράδειγμα: Late (Dynamic) Binding public class PolymorphismDemo { public static void m (Object x) { System.out.println(x.toString()); public static void main(string[] args) { m( new GraduateStudent() ); m( new Student() ); m( new Person() ); m( new Object() ); class GraduateStudent extends Student { class Student extends Person { public String tostring() { return "Student"; class Person extends Object { public String tostring() {return "Person"; Η μέθοδοςm() παίρνει σαν παράμετρο Object Μπορεί να καλεστεί με οποιοδήποτε αντικείμενο αφού όλα τα αντικείμενα κληρωνόμουν από το Object ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 49

50 Παράδειγμα: Late (Dynamic) Binding public class PolymorphismDemo { public static void m (Object x) { System.out.println(x.toString()); public static void main(string[] args) { m( new GraduateStudent() ); m( new Student() ); m( new Person() ); m( new Object() ); class GraduateStudent extends Student { class Student extends Person { public String tostring() { return "Student"; class Person extends Object { public String tostring() {return "Person"; Η μέθοδοςm() μπορεί να καλεστεί με οποιοδήποτε αντικείμενο κληρονομεί από το αντικείμενο που δέχεται σαν παράμετρος πολυμορφισμός ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 50

51 Παράδειγμα: Late (Dynamic) Binding public class PolymorphismDemo { public static void m (Object x) { System.out.println(x.toString()); public static void main(string[] args) { m( new GraduateStudent() ); m( new Student() ); m( new Person() ); m( new Object() ); class GraduateStudent extends Student { class Student extends Person { public String tostring() { return "Student"; class Person extends Object { public String tostring() {return "Person"; Όταν εκτελείτε η μέθοδος m()το αντικείμενο μπορεί να είναι του τύπου: GraduateStudent ή Student ή Person ή Object Η κάθε κλάση έχει δική της υλοποίηση για τη μέθοδο tostring() Ποια θα καλεστεί; Αποφασίζεται από την JVM run-time ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 51

52 Late (Dynamic) Binding Έστω ότι ένα αντικείμενο o είναι ένα στιγμιότυπο της κλάσης C 1,C 2, C n. C n C n-1 C 2 C 1 Αν το αντικείμενο o καλέσει την μέθοδο p() το JVM ψάχνει την υλοποίηση της μεθόδου p() στις κλάσεις C 1, C 2, C n με την σειρά μέχρι να τη βρει. Η πρώτη εκτέλεση που θα βρεθεί, θα εκτελεστεί ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 52

53 Μετατροπές αντικειμένων (Casting Objects) Το castingμπορεί να χρησιμοποιηθεί για να μετατραπεί ένα αντικείμενο από ένα τύπο σε κάποιο άλλο της ιεραρχία της κληρονομικότητας Παράδειγμα: m( new Student() ); μετατρέπει το Student σε Object Το πιο πάνω είναι ισοδύναμο με Object o = new Student(); m( o ); Έχουμε μετατρέψει ένα αντικείμενο μίας υποκλάσης σε ένα αντικείμενο μίας υπερκλάσης upcasting ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 53

54 Upcasting Shape s = new Circle (); Shape upcasts to Circle Μέσα στο heap δημιουργείται ένα καινούριο αντικείμενο Circle (= new Circle). Υπακούει όμως την διαπροσωπεία της κλάσης Shape Αυτό «περιέχει» ένα αντικείμενο τύπου Shape s.draw(): late binding πολυμορφική κλήση στην Circle.draw() s.getarea() compile error (δεν υπακούει την διαπροσωπεία Shape) ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 54

55 Upcasting με Abstract Classes/Interfaces Μία αφαιρετική κλάση μπορεί να χρησιμοποιηθεί σαν τύπος, π.χ., GeometricObjectarray = new GeometricObject[10];(μέσω από πολυμορφισμό) Δείκτες σε αντικείμενα μπορούν να έχουν τύπο διαπροσωπείας(μέσω από πολυμορφισμό) Για παράδειγμα: ΙΑnimals a = new Lion(); To IAnimals είναι διαπροσωπεία To Lionείναι κλάση Τι έχουμε πετύχει με την πιο πάνω δήλωση; Μόνο μεθόδοι που ανήκουν στην διαπροσωπεία IAnimals μπορούν να κληθούν! ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 55

56 Down-Casting vs. Up-Casting Το πιο κάτω δημιουργεί σφάλμα μεταγλώττισης Student s = new Object(); //downcasting Αυτό (Object o = new Student();) όμως ΟΧΙ. Ο λόγος είναι ότι Ένα αντικείμενο τύπου Student περιέχει/είναι ένα αντικείμενο τύπου Object Το αντίστροφο όμως δεν ισχύει, π.χ., Object o = new Αpple(); //ΟΚ Student s = ο; σημαίνει ότι ο s είναι μήλο! Πρέπει να χρησιμοποιηθεί άμεσο/explicitcastingγια να επιτραπεί από τον μεταγλωττιστή π.χ., Student s = (Student) new Object(); ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 56

57 Φωλιασμένες Κλάσεις (Nested Classes) Οι κλάσεις listener που υλοποιήσαμε έχουν σχεδιαστεί για να δημιουργηθούν διαχειριστές συμβάντων για διάφορα αντικείμενα (π.χ., για ένα κουμπί) Αυτές οι κλάσεις δεν θα χρησιμοποιηθούν από καμία άλλη κλάση είτε εντός ή εκτός εφαρμογής Για αυτό το λόγο είναι πιο σωστό αυτές οι κλάσεις να ισχύουν μόνο σε επίπεδο της κλάσης που έχουν οριστεί Αυτές οι κλάσεις αποτελούν «πεδία» των κλάσεων που έχουν οριστεί Κλάσεις που ορίζονται μέσα σε μία άλλη κλάση Φωλιασμένες Κλάσεις (Nested Classes) ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 57

58 Παράδειγμα Φωλιασμένων Κλάσεων import public class NestedClassExample extends JFrame { // Create two buttons JButton jbtok = new JButton("OK"); JButton jbtcancel = new JButton("Cancel"); class OKListenerClass implements ActionListener { public void actionperformed(actionevent e) { System.out.println("OK"); class CanceListenerClass implements ActionListener { public void actionperformed(actionevent e) { System.out.println("Cancel"); Παραδείγματα Φωλιασμένων Κλάσεων public NestedClassExample () { setlayout(new FlowLayout(FlowLayout.LEFT, 10, 20)); add(jbtok); add(jbtcancel); jbtok.addactionlistener(new OKListenerClass()); jbtcancel.addactionlistener(new CanceListenerClass()); public static void main(string[] args) { NestedClassExample frame = new NestedClassExample(); ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 58

59 Ταξινομία Κλάσεων Classes Top-level Πρέπει να ορίζονται σαν µέλη στη δήλωση µίας κλάσης Μη-στατικά µέλη Member Inner Nested local anonymous Πρέπει να ορίζονται µέσα σε εξωτερική κλάση Πρέπει να ορίζονται µέσα σε µία µέθοδο ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 59

60 Φωλιασμένες Κλάσεις-Αποθήκευση σε Αρχεία(συν.) class OuterClass { OuterClass.class static class NestedClass { class InnerMemberClass { OuterClass(){ class InnerLocalClass { int x; private Object method() { return new Object() { int x=5; ; public static void main( String[] args) { OuterClass o = new OuterClass(); OuterClass$Neste dclass.class OuterClass$InnerMe mberclass.class OuterClass$1Inner LocalClass.class OuterClass$1.class ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 60

61 Χρήσιμες Βιβλιοθήκες(java.lang.Math) Σταθερές Κλάσης: PI: το π = E: το e = Μέθοδοι Κλάσης: Trigonometric Methods: π.χ., sin(double a), cos(double a) Exponent Methods:π.χ., log10(double a), pow(double a, double b), sqrt(double a) Rounding Methods:π.χ., double ceil(double x), double floor(double x) Other methods: min, max, abs, and random Παραδείγματα: Math.sin(Math.PI / 2) = 1.0 Math.cos(0) = 1.0 Math.exp(1) = 2.71 Math.log(2.71) = 1.0 Math.pow(2, 3) = 8.0 Math.ceil(2.1) = 3.0 Math.floor(2.1) = 2.0 Math.ceil(-2.1) = -2.0 Math.max(2, 3) = 3 Math.min(2.5, 3.6) = 2.5 Math.abs(-2) = 2 0 <= Math.random() < 1.0 (int)(math.random() * 10) = [0..9] ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 61

Διάλεξη 16-17: Πολυμορφισμός (Polymorphism) Διδάσκων: Παναγιώτης Ανδρέου

Διάλεξη 16-17: Πολυμορφισμός (Polymorphism) Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 16-17: Πολυμορφισμός (Polymorphism) Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: -Υπερφόρτωση (Overloading), Μεθόδων (Method Overloading), Τελεστών (Operator Overloading (C++, C#))

Διαβάστε περισσότερα

ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 2. Επανάληψη Java + OOP ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 1 Διάλεξη 02: Αντικειμενοστρεφής Προγραμματισμός με την JAVA Στην ενότητα αυτή θα μελετηθούν τα εξής

Διαβάστε περισσότερα

Διάλεξη 3: Προγραμματισμός σε JAVA I. Διδάσκων: Παναγιώτης Ανδρέου

Διάλεξη 3: Προγραμματισμός σε JAVA I. Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 3: Προγραμματισμός σε JAVA I Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Εισαγωγή στις έννοιες: - Στοιχειώδης Προγραμματισμός - Προγραμματισμός με Συνθήκες - Προγραμματισμός με Βρόγχους

Διαβάστε περισσότερα

Διάλεξη 4: Προγραμματισμός σε JAVA IΙ. Διδάσκων: Παναγιώτης Ανδρέου

Διάλεξη 4: Προγραμματισμός σε JAVA IΙ. Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 4: Προγραμματισμός σε JAVA IΙ Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Εισαγωγή στις έννοιες: -Μέθοδοι - Πίνακες, Πολυδιάστατοι Πίνακες - Boxing/Unboxing - Χρήσιμες βιβλιοθήκες

Διαβάστε περισσότερα

Διδάσκων: Παναγιώτης Ανδρέου

Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 15: Αφαιρετικές Κλάσεις (Abstract Classes)& Διαπροσωπείες (Interfaces) Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Αφαιρετικές Κλάσεις, Αφαιρετικές Μεθόδοι - Διαπροσωπείες: Ορισμός,

Διαβάστε περισσότερα

Διδάσκων: Παναγιώτης Ανδρέου

Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 12: Κληρονομικότητα (Inheritance) Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Κληρονομικότητα και Επαναχρησιμοποίηση - Υποκλάσεις/Υπερκλάσεις - Απόκρυψη ονομάτων - Το super, protected

Διαβάστε περισσότερα

Διάλεξθ 02: Αντικειμενοςτρεφισ Προγραμματιςμόσ με τθν JAVA

Διάλεξθ 02: Αντικειμενοςτρεφισ Προγραμματιςμόσ με τθν JAVA Διάλεξθ 02: Αντικειμενοςτρεφισ Προγραμματιςμόσ με τθν JAVA Στην ενότητα αυτή θα μελετηθοφν τα εξήσ επιμζρουσ θζματα: Ειςαγωγι ςτισ ζννοιεσ: - Επιςκόπθςθ τθσ JAVA - Περιςςότερεσ Πλθροφορίεσ ςτο μάκθμα ΕΠΛ233

Διαβάστε περισσότερα

Διάλεξη 1: Αντικειμενοστρεφής Προγραμματισμός -Εισαγωγή. Διδάσκων: Παναγιώτης Ανδρέου

Διάλεξη 1: Αντικειμενοστρεφής Προγραμματισμός -Εισαγωγή. Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 1: Αντικειμενοστρεφής Προγραμματισμός -Εισαγωγή Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Εισαγωγή στις έννοιες: - Γλώσσες Προγραμματισμού - Μεταγλώττιση και Διερμηνεία -Η πλατφόρμα

Διαβάστε περισσότερα

Αντικειμενοστρεφής Προγραμματισμός

Αντικειμενοστρεφής Προγραμματισμός Αντικειμενοστρεφής Προγραμματισμός Διδάσκουσα: Αναπλ. Καθηγήτρια Ανδριάνα Πρέντζα aprentza@unipi.gr Εργαστηριακός Συνεργάτης: Δρ. Βασιλική Κούφη vassok@unipi.gr Εργαστήριο 2 Βασικοί Τύποι Μεταβλητών Java

Διαβάστε περισσότερα

ΑΤΕΙ ΘΕΣΣΑΛΟΝΙΚΗΣ ΤΜΗΜΑ ΜΗΧΑΝΙΚΩΝ ΠΛΗΡΟΦΟΡΙΚΗΣ Αλγοριθμική και Προγραμματισμός. Περισσότερα για τις Κλάσεις, τα Αντικείμενα και τις Μεθόδους

ΑΤΕΙ ΘΕΣΣΑΛΟΝΙΚΗΣ ΤΜΗΜΑ ΜΗΧΑΝΙΚΩΝ ΠΛΗΡΟΦΟΡΙΚΗΣ Αλγοριθμική και Προγραμματισμός. Περισσότερα για τις Κλάσεις, τα Αντικείμενα και τις Μεθόδους ΑΤΕΙ ΘΕΣΣΑΛΟΝΙΚΗΣ ΤΜΗΜΑ ΜΗΧΑΝΙΚΩΝ ΠΛΗΡΟΦΟΡΙΚΗΣ Αλγοριθμική και Προγραμματισμός Παναγιώτης Σφέτσος sfetsos@it.teithe.gr Περισσότερα για τις Κλάσεις, τα Αντικείμενα και τις Μεθόδους Σύνοψη των βασικών λειτουργιών

Διαβάστε περισσότερα

ΠΛΗΡΟΦΟΡΙΚΗ ΙΙ (JAVA) 11/3/2008

ΠΛΗΡΟΦΟΡΙΚΗ ΙΙ (JAVA) 11/3/2008 ΠΛΗΡΟΦΟΡΙΚΗ ΙΙ (JAVA) 11/3/2008 Κατασκευαστές (Constructors) Ειδικός τύπος μεθόδων, οι οποίες: - είναι public και έχουν το ίδιο όνομα με αυτό της κλάσης - χρησιμοποιούνται για να αρχικοποιήσουν κάποιες

Διαβάστε περισσότερα

Διάλεξη 5: Κλάσεις και Αντικείμενα. Διδάσκων: Παναγιώτης Ανδρέου

Διάλεξη 5: Κλάσεις και Αντικείμενα. Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 5: Κλάσεις και Αντικείμενα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Εισαγωγή στις έννοιες: - Κλάσεις και Αντικείμενα - Κατασκευή, Πρόσβαση Αντικειμένων - Διαχείριση Μνήμης, Garbage

Διαβάστε περισσότερα

Εργαστήριο 02: Προγραμματισμός με Γενικούς Τύπους (JAVA Generics) ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι

Εργαστήριο 02: Προγραμματισμός με Γενικούς Τύπους (JAVA Generics) ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι Εργαστήριο 02: Προγραμματισμός με Γενικούς Τύπους (JAVA Generics) ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 1 Generic Types Τα Generics έχουν προστεθεί στη JAVA από το 2004 ως μέρος του J2SE 5.0 Με τη χρήση

Διαβάστε περισσότερα

Εισαγωγή στη γλώσσα προγραμματισμού JAVA. Δομές Δεδομένων Διδάσκων: Π.Α. Μήτκας Τομέας Ηλεκτρονικής και Υπολογιστών

Εισαγωγή στη γλώσσα προγραμματισμού JAVA. Δομές Δεδομένων Διδάσκων: Π.Α. Μήτκας Τομέας Ηλεκτρονικής και Υπολογιστών Εισαγωγή στη γλώσσα προγραμματισμού JAVA Δομές Δεδομένων Διδάσκων: Π.Α. Μήτκας Τομέας Ηλεκτρονικής και Υπολογιστών Το πρώτο φλιτζάνι Java Λίστα με τα απαραίτητα Το πρώτο μου πρόγραμμα(hello World) Συνεχίζοντας

Διαβάστε περισσότερα

Διδάσκων: Παναγιώτης Ανδρέου

Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 19: Φωλιασμένες (Nested) και Εσωτερικές (Inner) κλάσεις Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Φωλιασμένες Κλάσεις - Εσωτερικές Κλάσεις (Τοπικές και Ανώνυμες) - Ταξινομία Κλάσεων

Διαβάστε περισσότερα

Αντικειµενοστρεφής Προγραµµατισµός

Αντικειµενοστρεφής Προγραµµατισµός 16 η διάλεξη Π. Σταθοπούλου pstath@ece.upatras.gr ή pstath@upatras.gr Οµάδα Α (Φοιτητές µε µονό αριθµό Μητρώου ) ιδασκαλία : Παρασκευή 11πµ-13µµ ΗΛ7 Φροντιστήριο : ευτέρα 11πµ-12πµ ΗΛ4 Προηγούµενη ιάλεξη

Διαβάστε περισσότερα

Η λέξη κλειδί this. Γαβαλάς Δαμιανός dgavalas@aegean.gr

Η λέξη κλειδί this. Γαβαλάς Δαμιανός dgavalas@aegean.gr Αντικειμενοστραφής Προγραμματισμός I (5 ο εξ) Διάλεξη #6 η : Η λέξη κλειδί this, υπερφόρτωση μεθόδων, κληρονομικότητα, πολυμορφισμός, υπερκάλυψη, επίπεδα προσπέλασης Γαβαλάς Δαμιανός dgavalas@aegean.gr

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Constructors, equals, tostring

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Constructors, equals, tostring ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Κλάσεις και Αντικείμενα Constructors, equals, tostring Constructors (Δημιουργοί) O Constructor είναι μια «μέθοδος» η οποία καλείται όταν δημιουργούμε το αντικείμενο

Διαβάστε περισσότερα

Εισαγωγή στον Αντικειμενοστρέφή Προγραμματισμό Διάλεξη #12

Εισαγωγή στον Αντικειμενοστρέφή Προγραμματισμό Διάλεξη #12 Διάγραμμα κλάσεων [Class diagram] Διάλεξη #12: Υπο-τύποι και πολυμορφισμός [sub-typing and polymorphism] Database Music Εισαγωγή στον Αντικειμενοστρεφή Προγραμματισμό,, Slide 1 Εισαγωγή στον Αντικειμενοστρεφή

Διαβάστε περισσότερα

Το πρόγραμμα HelloWorld.java. HelloWorld. Κλάσεις και Αντικείμενα (2) Ορισμός μιας Κλάσης (1) Παύλος Εφραιμίδης pefraimi <at> ee.duth.

Το πρόγραμμα HelloWorld.java. HelloWorld. Κλάσεις και Αντικείμενα (2) Ορισμός μιας Κλάσης (1) Παύλος Εφραιμίδης pefraimi <at> ee.duth. Το πρόγραμμα HelloWorld.java Σχόλια στη Java HelloWorld Παύλος Εφραιμίδης pefraimi ee.duth.gr Java Το πρόγραμμα HelloWorld 1 Java Το πρόγραμμα HelloWorld 2 Σχόλια στη Java ΗγλώσσαJava υποστηρίζει

Διαβάστε περισσότερα

Κλάσεις και Αντικείµενα

Κλάσεις και Αντικείµενα Κλάσεις και Αντικείµενα Γρηγόρης Τσουµάκας Τµήµα Πληροφορικής, Αριστοτέλειο Πανεπιστήµιο Θεσσαλονίκης Κλάσεις και Αντικείµενα 2 Τα αντικείµενα σε µια αντικειµενοστρεφή γλώσσα προγραµµατισµού, µοντελοποιούν

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java III

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java III ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Εισαγωγή στη Java III Ισότητα Strings class StringTest public static void main(string args[]) String x1 = "java"; String y1 = "java"; System.out.println("1.

Διαβάστε περισσότερα

Υπερφόρτωση (Overloading) Υπέρβαση (Overriding) - Upcasting Downcasting Final classes, methods

Υπερφόρτωση (Overloading) Υπέρβαση (Overriding) - Upcasting Downcasting Final classes, methods (Object Oriented Programming) Υπερφόρτωση (Overloading) Υπέρβαση (Overriding) - Upcasting Downcasting Final classes, methods PhD http://aetos.it.teithe.gr/~sfetsos/ sfetsos@it.teithe.gr Περιεχόμενα Μαθήματος

Διαβάστε περισσότερα

Διασυνδέσεις / Διεπαφές. Παναγιώτης Σφέτσος, PhD

Διασυνδέσεις / Διεπαφές. Παναγιώτης Σφέτσος, PhD (Object Oriented Programming) Διασυνδέσεις / Διεπαφές PhD http://aetos.it.teithe.gr/~sfetsos/ sfetsos@it.teithe.gr Περιεχόμενα Μαθήματος Διεπαφές/Διασυνδέσεις (Interfaces) 2 Διεπαφές/Διασυνδέσεις (Interfaces)

Διαβάστε περισσότερα

Βασικά Στοιχεία της Java

Βασικά Στοιχεία της Java Βασικά Στοιχεία της Java Παύλος Εφραιμίδης Java Βασικά Στοιχεία της γλώσσας Java 1 Τύποι Δεδομένων Η Java έχει δύο κατηγορίες τύπων δεδομένων: πρωτογενείς (primitive) τύπους δεδομένων αναφορές Java Βασικά

Διαβάστε περισσότερα

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

Εισαγωγή στον Προγ/μό Η/Υ Εισαγωγή στον Προγ/μό Η/Υ Ενότητα 7 2ο μέρος: Επιπλέον έννοιες σχετικά με αντικείμενα Διδάσκων: Μιχάλης Τίτσιας Περιεχόμενα Τι μπορεί να περιέχει μια τάξη Μέθοδοι τάξης και σταθερές τάξης Πολυμορφισμός

Διαβάστε περισσότερα

Wrapper Classes, Abstract Classes and Interfaces

Wrapper Classes, Abstract Classes and Interfaces Wrapper Classes, Abstract Classes and Interfaces Εβδοµάδα 3: Κλάσεις συσκευαστές, αφηρηµένες κλάσεις και διαπροσωπείες Αντικείµενα και µη-αντικείµενα Η Java παρέχει τύπους αντικειµένων και απλούς τύπους

Διαβάστε περισσότερα

Εισαγωγή στον Αντικειμενοστρέφή Προγραμματισμό Διάλεξη #13

Εισαγωγή στον Αντικειμενοστρέφή Προγραμματισμό Διάλεξη #13 Wrapper Classes, Abstract Classes and Interfaces Διάλεξη #13: Μεταβλητές/μέθοδοι κλάσης, αφηρημένες κλάσεις και διαπροσωπείες Μεταβλητές /πεδία κλάσης [class variables] Τα αντικείμενα ανήκουν σε κλάσεις

Διαβάστε περισσότερα

class object Database Database Item Item [sub-typing and polymorphism] MusicCD Video MusicCD Video

class object Database Database Item Item [sub-typing and polymorphism] MusicCD Video MusicCD Video ιάγραµµα κλάσεων [Class diagram] Εβδοµάδα 2: Υπο-τύποι και πολυµορφισµός [sub-typing and polymorphism] Database Music Σχεδίαση-Ανάπτυξη Εφαρµογών Πληροφορικής Αντώνιος Συµβώνης, ΕΜΠ, Slide 1 Σχεδίαση-Ανάπτυξη

Διαβάστε περισσότερα

Αντικειμενοστρεφής Προγραμματισμός

Αντικειμενοστρεφής Προγραμματισμός Πανεπιστήμιο Πειραιά Τμήμα Ψηφιακών Συστημάτων Αντικειμενοστρεφής Προγραμματισμός 16/4/2018 Δρ. Ανδριάνα Πρέντζα Αναπληρώτρια Καθηγήτρια aprentza@unipi.gr Τύποι της Java Primitives vs References Οι πρωταρχικοί

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Στοίβα και Σωρός Αναφορές-Παράμετροι

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Στοίβα και Σωρός Αναφορές-Παράμετροι ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Αναφορές Στοίβα και Σωρός Αναφορές-Παράμετροι new Όπως είδαμε για να δημιουργήσουμε ένα αντικείμενο χρειάζεται να καλέσουμε τη new. Για τον πίνακα είπαμε ότι

Διαβάστε περισσότερα

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

8. Μέθοδοι (Methods) 8. Μέθοδοι (Methods) Χειμερινό εξάμηνο 2012 Πέτρος Κωμοδρόμος komodromos@ucy.ac.cy http://www.eng.ucy.ac.cy/petros 1 Θέματα Μέθοδοι που παρέχονται από τη τάξη Math του Java API Χρήση στατικών μεθόδων και

Διαβάστε περισσότερα

(Διαφάνειες Νίκου Βιδάκη)

(Διαφάνειες Νίκου Βιδάκη) (Διαφάνειες Νίκου Βιδάκη) JAVA Inheritance Εβδομάδα Νο. 3 2 Προηγούμενο μάθημα (1/2) Τι είναι αντικείμενο? Ανάλυση αντικειμένων Πραγματικά αντικείμενα Καταστάσεις Συμπεριφορές Αντικείμενα στον προγραμματισμό

Διαβάστε περισσότερα

ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με Α.Μ. σε 8 & 9 18/10/07

ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με Α.Μ. σε 8 & 9 18/10/07 ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με Α.Μ. σε 8 & 9 18/10/07 Αλγόριθμος: Βήμα προς βήμα διαδικασία για την επίλυση κάποιου προβλήματος. Το πλήθος των βημάτων πρέπει να είναι πεπερασμένο. Αλλιώς: Πεπερασμένη

Διαβάστε περισσότερα

Εισαγωγή στον Αντικειμενοστρεφή Προγραμματισμό Διάλεξη #2

Εισαγωγή στον Αντικειμενοστρεφή Προγραμματισμό Διάλεξη #2 Ανασκόπηση Μια εφαρμογή Java είναι ένα σύνολο από συνεργαζόμενες κλάσεις Διάλεξη #2: Αντικείμενα, Κλάσεις και Μέθοδοι Εισαγωγή στον Αντικειμενοστρεφή Προγραμματισμό,, Slide 1 Εισαγωγή στον Αντικειμενοστρεφή

Διαβάστε περισσότερα

Αρχές Τεχνολογίας Λογισμικού Εργαστήριο

Αρχές Τεχνολογίας Λογισμικού Εργαστήριο Αρχές Τεχνολογίας Λογισμικού Εργαστήριο Κωδικός Μαθήματος: TP323 Ώρες Εργαστηρίου: 2/εβδομάδα (Διαφάνειες Νίκου Βιδάκη) 1 JAVA Inheritance Εβδομάδα Νο. 3 2 Προηγούμενο μάθημα (1/2) Τι είναι αντικείμενο?

Διαβάστε περισσότερα

2.1 Αντικειµενοστρεφής προγραµµατισµός

2.1 Αντικειµενοστρεφής προγραµµατισµός 2.1 Αντικειµενοστρεφής προγραµµατισµός Στον αντικειµενοστρεφή προγραµµατισµό (object oriented programming, OOP) ένα πρόγραµµα υπολογιστή είναι ένα σύνολο αλληλεπιδρώντων αντικειµένων. Μπορεί να ειπωθεί

Διαβάστε περισσότερα

Αντικειμενοστρεφής Προγραμματισμός Διάλεξη 9 : ΑΦΗΡΗΜΕΝΕΣ ΚΛΑΣΕΙΣ

Αντικειμενοστρεφής Προγραμματισμός Διάλεξη 9 : ΑΦΗΡΗΜΕΝΕΣ ΚΛΑΣΕΙΣ Αντικειμενοστρεφής Προγραμματισμός Διάλεξη 9 : ΑΦΗΡΗΜΕΝΕΣ ΚΛΑΣΕΙΣ INTERFACES ΕΣΩΤΕΡΙΚΕΣ ΚΛΑΣΕΙΣ (INNER CLASSES) Αφηρημένες Κλάσεις (Abstract Classes) (1/6) Οι αφηρημένες κλάσεις χρησιμοποιούνται για την

Διαβάστε περισσότερα

HelloWorld. Παύλος Εφραιμίδης. Java Το πρόγραμμα HelloWorld 1

HelloWorld. Παύλος Εφραιμίδης. Java Το πρόγραμμα HelloWorld 1 HelloWorld Παύλος Εφραιμίδης Java Το πρόγραμμα HelloWorld 1 Το πρόγραμμα HelloWorld.java Σχόλια στη Java /** * The HelloWorld class */ class HelloWorld { public static void main(string[] args) { System.out.println("Hello

Διαβάστε περισσότερα

ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με Α.Μ. σε 3, 7, 8 & 9 25/10/07

ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με Α.Μ. σε 3, 7, 8 & 9 25/10/07 ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με Α.Μ. σε 3, 7, 8 & 9 25/10/07 Αριθμητική στο δυαδικό σύστημα (γενικά) Συμπληρωματικά για δυαδικό σύστημα Η πρόσθεση στηρίζεται στους κανόνες: 0 + 0 = 0, 0 + 1 = 1, 1

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Στοίβα και Σωρός Μνήμης Αντικείμενα ως ορίσματα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Στοίβα και Σωρός Μνήμης Αντικείμενα ως ορίσματα ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Αναφορές Στοίβα και Σωρός Μνήμης Αντικείμενα ως ορίσματα ΑΝΑΦΟΡΕΣ new Όπως είδαμε για να δημιουργήσουμε ένα αντικείμενο χρειάζεται να καλέσουμε τη new. Για

Διαβάστε περισσότερα

Κλάσεις στη Java. Στοίβα - Stack. Δήλωση της κλάσης. ΗκλάσηVector της Java. Ηκλάση Stack

Κλάσεις στη Java. Στοίβα - Stack. Δήλωση της κλάσης. ΗκλάσηVector της Java. Ηκλάση Stack Κλάσεις στην Java Κλάσεις στη Java Παύλος Εφραιμίδης Θα δούμε τη διαδικασία δημιουργίας μιας κλάσης Θα υλοποιήσουμε μια κλάση για τη Δομή Δεδομένων Stack Java Κλάσεις στη Java 1 Java Κλάσεις στη Java 2

Διαβάστε περισσότερα

Βασικά Στοιχεία της Java

Βασικά Στοιχεία της Java Βασικά Στοιχεία της Παύλος Εφραιμίδης 1 Βασικά Στοιχεία της γλώσσας Τύποι Δεδομένων Η έχει δύο κατηγορίες τύπων δεδομένων: πρωτογενείς (primitive) iti τύπους δεδομένων δδ αναφορές 2 Βασικά Στοιχεία της

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java III

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java III ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Εισαγωγή στη Java III Το if-else statement Το if-else statement δουλεύει καλά όταν στο condition θέλουμε να περιγράψουμε μια επιλογή με δύο πιθανά ενδεχόμενα.

Διαβάστε περισσότερα

3 Αλληλεπίδραση Αντικειμένων

3 Αλληλεπίδραση Αντικειμένων Αφαίρεση και Αρθρωσιμότητα 3 Αλληλεπίδραση Αντικειμένων Πώς συνεργάζονται τα αντικείμενα που δημιουργούμε Αφαίρεση (abstraction) είναι η δυνατότητα να αγνοούμε τις λεπτομέρειες και να εστιάζουμε την προσοχή

Διαβάστε περισσότερα

Κλάσεις στη Java. Παύλος Εφραιμίδης. Java Κλάσεις στη Java 1

Κλάσεις στη Java. Παύλος Εφραιμίδης. Java Κλάσεις στη Java 1 Κλάσεις στη Java Παύλος Εφραιμίδης Java Κλάσεις στη Java 1 Κλάσεις στην Java Θα δούμε τη διαδικασία δημιουργίας μιας κλάσης Θα υλοποιήσουμε μια κλάση για τη Δομή Δεδομένων Stack Java Κλάσεις στη Java 2

Διαβάστε περισσότερα

02 Αντικειμενοστρεφής Προγραμματισμός

02 Αντικειμενοστρεφής Προγραμματισμός 02 Αντικειμενοστρεφής Προγραμματισμός Τεχνολογία Λογισμικού Τμήμα Πληροφορικής & Τηλεπικοινωνιών, ΕΚΠΑ Εαρινό εξάμηνο 2016 17 Δρ. Κώστας Σαΐδης saiko@di.uoa.gr Αντικειμενοστρέφεια Στον προγραμματισμό object

Διαβάστε περισσότερα

Αντικειμενοστρεφής Προγραμματισμός

Αντικειμενοστρεφής Προγραμματισμός Αντικειμενοστρεφής Προγραμματισμός Διδάσκουσα: Αναπλ. Καθηγήτρια Ανδριάνα Πρέντζα aprentza@unipi.gr Εργαστηριακός Συνεργάτης: Δρ. Βασιλική Κούφη vassok@unipi.gr Περιεχόμενα Java Classes Java Objects Java

Διαβάστε περισσότερα

public void printstatement() { System.out.println("Employee: " + name + " with salary: " + salary);

public void printstatement() { System.out.println(Employee:  + name +  with salary:  + salary); Κληρονομικότητα Η κληρονομικότητα (inheritance) αποτελεί έναν από τους χαρακτηριστικότερους μηχανισμούς των αντικειμενοστρεφών γλωσσών προγραμματισμού. Επιτρέπει την δημιουργία μιας νέας κλάσης απορροφώντας

Διαβάστε περισσότερα

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

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Στατικές μέθοδοι και μεταβλητές Εσωτερικές κλάσεις ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Στατικές μέθοδοι και μεταβλητές Εσωτερικές κλάσεις Στατικές μέθοδοι Τι σημαίνει το keyword static στον ορισμό της main μεθόδου? Τι είναι μια στατική μέθοδος?

Διαβάστε περισσότερα

Αντικειμενοστραφής Προγραμματισμός I (5 ο εξ) Εργαστήριο #1 ο : Εισαγωγή στο Περιβάλλον Ανάπτυξης (IDE)

Αντικειμενοστραφής Προγραμματισμός I (5 ο εξ) Εργαστήριο #1 ο : Εισαγωγή στο Περιβάλλον Ανάπτυξης (IDE) Αντικειμενοστραφής Προγραμματισμός I (5 ο εξ) Εργαστήριο #1 ο : Εισαγωγή στο Περιβάλλον Ανάπτυξης (IDE) NetBeans, Πρώτα παραδείγματα ανάπτυξης Java εφαρμογών Γαβαλάς Δαμιανός dgavalas@aegean.gr Στόχοι

Διαβάστε περισσότερα

Σχεδίαση Εφαρμογών και Υπηρεσιών Διαδικτύου 7 η Διάλεξη: Σύντομη εισαγωγή στην Java

Σχεδίαση Εφαρμογών και Υπηρεσιών Διαδικτύου 7 η Διάλεξη: Σύντομη εισαγωγή στην Java Σχεδίαση Εφαρμογών και Υπηρεσιών Διαδικτύου 7 η Διάλεξη: Σύντομη εισαγωγή στην Java Δρ. Απόστολος Γκάμας Λέκτορας (407/80) gkamas@uop.gr Σχεδίαση Εφαρμογών και Υπηρεσιών Διαδικτύου Διαφάνεια 1 Εισαγωγή

Διαβάστε περισσότερα

Αντικειμενοστρεφής Προγραμματισμός Διάλεξη 2 : ΜΕΤΑΒΛΗΤΕΣ ΤΕΛΕΣΤΕΣ & ΕΚΦΡΑΣΕΙΣ ΕΛΕΓΧΟΣ ΡΟΗΣ

Αντικειμενοστρεφής Προγραμματισμός Διάλεξη 2 : ΜΕΤΑΒΛΗΤΕΣ ΤΕΛΕΣΤΕΣ & ΕΚΦΡΑΣΕΙΣ ΕΛΕΓΧΟΣ ΡΟΗΣ Αντικειμενοστρεφής Προγραμματισμός Διάλεξη 2 : ΜΕΤΑΒΛΗΤΕΣ ΤΕΛΕΣΤΕΣ & ΕΚΦΡΑΣΕΙΣ ΕΛΕΓΧΟΣ ΡΟΗΣ Κων. Κόκκινος Μεταβλητές-1 Οι μεταβλητές αποτελούν θέσεις μνήμης στις οποίες αποθηκεύονται τιμές αντίστοιχες

Διαβάστε περισσότερα

Οντοκεντρικός Προγραμματισμός ΦΡΟΝΤΙΣΤΗΡΙΟ JAVA

Οντοκεντρικός Προγραμματισμός ΦΡΟΝΤΙΣΤΗΡΙΟ JAVA Οντοκεντρικός Προγραμματισμός ΦΡΟΝΤΙΣΤΗΡΙΟ JAVA Τι θα συζητήσουμε σήμερα Πώς υλοποιούμε συσχετίσεις μεταξύ κλάσεων απλές και πολλαπλές συσχετίσεις κληρονομικότητα Static, final Overloading Overriding Hiding

Διαβάστε περισσότερα

. Μεθοδολογία Προγραμματισμού. Abstract Κλάσεις και Interfaces. Νικόλαος Πεταλίδης. Εισαγωγή Εαρινό Εξάμηνο 2014

. Μεθοδολογία Προγραμματισμού. Abstract Κλάσεις και Interfaces. Νικόλαος Πεταλίδης. Εισαγωγή Εαρινό Εξάμηνο 2014 .. Μεθοδολογία Προγραμματισμού Abstract Κλάσεις και Interfaces Νικόλαος Πεταλίδης Τμήμα Μηχανικών Η/Υ ΤΕΙ Κεντρικής Μακεδονίας Εισαγωγή Εαρινό Εξάμηνο 2014 Ν. Πεταλίδης (ΤΕΙ Κεντρικής Μακεδονίας) Μεθοδολογία

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Εισαγωγή στη Java Είσοδος Χρησιμοποιούμε την κλάση Scanner της Java import java.util.scanner; Αρχικοποιείται με το ρεύμα εισόδου: Scanner in = new Scanner(System.in);

Διαβάστε περισσότερα

Αντικειμενοστραφής Προγραμματισμός I(5 ο εξ) Εργαστήριο #1 ο : Εισαγωγή στο Περιβάλλον Ανάπτυξης (IDE)

Αντικειμενοστραφής Προγραμματισμός I(5 ο εξ) Εργαστήριο #1 ο : Εισαγωγή στο Περιβάλλον Ανάπτυξης (IDE) Αντικειμενοστραφής Προγραμματισμός I(5 ο εξ) Εργαστήριο #1 ο : Εισαγωγή στο Περιβάλλον Ανάπτυξης (IDE) NetBeans, Πρώτα παραδείγματα ανάπτυξης Java εφαρμογών Στόχοι εργαστηρίου Εξοικείωση με τις βασικές

Διαβάστε περισσότερα

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

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Μέθοδοι ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Κλάσεις και Αντικείμενα Μέθοδοι Παράδειγμα Θέλουμε ένα πρόγραμμα που να προσομοιώνει την κίνηση ενός αυτοκινήτου, το οποίο κινείται και τυπώνει τη θέση του.

Διαβάστε περισσότερα

Γενικά (για τις γραπτές εξετάσεις)

Γενικά (για τις γραπτές εξετάσεις) Αντικειμενοστραφής Προγραμματισμός I (5 ο εξ) Διάλεξη #12 η : Επανάληψη Γαβαλάς Δαμιανός dgavalas@aegean.gr Γενικά (για τις γραπτές εξετάσεις) Δεν υπάρχει αυστηρά ορισμένη «ύλη εξετάσεων» (καθώς δεν έχετε

Διαβάστε περισσότερα

Οντοκεντρικός Προγραμματισμός

Οντοκεντρικός Προγραμματισμός Οντοκεντρικός Προγραμματισμός Ενότητα 2: Η ΓΛΩΣΣΑ JAVA Βασικά Δομικά Στοιχεία ΔΙΔΑΣΚΟΝΤΕΣ: Ιωάννης Χατζηλυγερούδης, Χρήστος Μακρής Πολυτεχνική Σχολή Τμήμα Μηχανικών Η/Υ & Πληροφορικής ΔΟΜΙΚΑ ΣΤΟΙΧΕΙΑ ΔΟΜΙΚΑ

Διαβάστε περισσότερα

Οντοκεντρικός Προγραμματισμός

Οντοκεντρικός Προγραμματισμός Οντοκεντρικός Προγραμματισμός Ενότητα 5: H ΓΛΩΣΣΑ C++ Διαφορές Java και C++ ΔΙΔΑΣΚΟΝΤΕΣ: Ιωάννης Χατζηλυγερούδης, Χρήστος Μακρής Πολυτεχνική Σχολή Τμήμα Μηχανικών Η/Υ & Πληροφορικής ΔΙΑΦΟΡΕΣ JAVA C++ Η

Διαβάστε περισσότερα

Εισαγωγή στον Προγραµµατισµό, Αντώνιος Συµβώνης, ΣΕΜΦΕ, ΕΜΠ,, Slide 6

Εισαγωγή στον Προγραµµατισµό, Αντώνιος Συµβώνης, ΣΕΜΦΕ, ΕΜΠ,, Slide 6 Ανασκόπηση Μια εφαρµογή Java είναι ένα σύνολο από συνεργαζόµενες κλάσεις Εβδοµάδα 2: Αντικείµενα, Κλάσεις και Μέθοδοι Εισαγωγή στον Προγραµµατισµό,,, Slide 1 Εισαγωγή στον Προγραµµατισµό,,, Slide 2 Ανασκόπηση:

Διαβάστε περισσότερα

2.1. Εντολές. 2.2. Σχόλια. 2.3. Τύποι Δεδομένων

2.1. Εντολές. 2.2. Σχόλια. 2.3. Τύποι Δεδομένων 2 Βασικές Εντολές 2.1. Εντολές Οι στην Java ακολουθούν το πρότυπο της γλώσσας C. Έτσι, κάθε εντολή που γράφουμε στη Java θα πρέπει να τελειώνει με το ερωτηματικό (;). Όπως και η C έτσι και η Java επιτρέπει

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αντικείμενα ως ορίσματα Εισαγωγή στις αναφορές

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αντικείμενα ως ορίσματα Εισαγωγή στις αναφορές ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Αντικείμενα ως ορίσματα Εισαγωγή στις αναφορές Αντικείμενα ως ορίσματα Μπορούμε να περνάμε αντικείμενα ως ορίσματα σε μία μέθοδο όπως οποιαδήποτε άλλη μεταβλητή

Διαβάστε περισσότερα

Οντοκεντρικός Προγραμματισμός ΦΡΟΝΤΙΣΤΗΡΙΟ JAVA

Οντοκεντρικός Προγραμματισμός ΦΡΟΝΤΙΣΤΗΡΙΟ JAVA Οντοκεντρικός Προγραμματισμός ΦΡΟΝΤΙΣΤΗΡΙΟ JAVA Τι θα συζητήσουμε σήμερα Πώς υλοποιούμε συσχετίσεις μεταξύ κλάσεων απλές και πολλαπλές συσχετίσεις κληρονομικότητα Static, final Overloading Overriding Hiding

Διαβάστε περισσότερα

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

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Αναφορές ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Κλάσεις και Αντικείμενα Αναφορές Μαθήματα από το lab Υπενθύμιση: Η άσκηση ζητούσε να υλοποιήσετε μία κλάση vector που να διαχειρίζεται διανύσματα οποιουδήποτε

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Στοίβα και Σωρός Αναφορές-Παράμετροι String Interning

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Στοίβα και Σωρός Αναφορές-Παράμετροι String Interning ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Αναφορές Στοίβα και Σωρός Αναφορές-Παράμετροι String Interning new Όπως είδαμε για να δημιουργήσουμε ένα αντικείμενο χρειάζεται να καλέσουμε τη new. Για τον

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Στοίβα και Σωρός μνήμης Αντικείμενα παράμετροι String Interning

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Στοίβα και Σωρός μνήμης Αντικείμενα παράμετροι String Interning ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Αναφορές Στοίβα και Σωρός μνήμης Αντικείμενα παράμετροι String Interning Αποθήκευση αντικειμένων Οι θέσεις μνήμης των αντικειμένων κρατάνε μια διεύθυνση στο

Διαβάστε περισσότερα

Abstract classes, Interfaces ΦΡΟΝΤΙΣΤΗΡΙΟ JAVA

Abstract classes, Interfaces ΦΡΟΝΤΙΣΤΗΡΙΟ JAVA Abstract classes, Interfaces ΦΡΟΝΤΙΣΤΗΡΙΟ JAVA Τι θα συζητήσουμε σήμερα Αφαιρέσεις στη Java Abstract μέθοδοι και abstract κλάσεις Interfaces (=διασυνδέσεις, διεπαφές) Instanceof Παραδείγματα κώδικα Αφηρημένες

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Constructors, equals, tostring Αντικείμενα ως παράμετροι

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Constructors, equals, tostring Αντικείμενα ως παράμετροι ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Constructors, equals, tostring Αντικείμενα ως παράμετροι Constructors (Δημιουργοί) O Constructor είναι μια «μέθοδος» η οποία καλείται όταν δημιουργούμε το αντικείμενο

Διαβάστε περισσότερα

1 ΕΙΣΑΓΩΓΗ. Πρωταρχικοί Τύποι

1 ΕΙΣΑΓΩΓΗ. Πρωταρχικοί Τύποι 1 ΕΙΣΑΓΩΓΗ Η γλώσσα προγραµµατισµού Java είναι ισχυρά τυποποιηµένη (strongly typed), που σηµαίνει ότι κάθε µεταβλητή και κάθε έκφραση έχει κάποιο τύπο, ο οποίος πρέπει να είναι γνωστός κατά το χρόνο της

Διαβάστε περισσότερα

Τι χρειάζεται ένας φοιτητής για τη σωστή παρακολούθηση και συμμετοχή στο μαθημα;

Τι χρειάζεται ένας φοιτητής για τη σωστή παρακολούθηση και συμμετοχή στο μαθημα; Εισαγωγή Τι χρειάζεται ένας φοιτητής για τη σωστή παρακολούθηση και συμμετοχή στο μαθημα; 1. Σελίδα μαθήματος Εγγραφή Ο κάθε φοιτητής πρέπει να κάνει εγγραφή στη σελίδα του μαθήματος στην πλατφόρμα e-class

Διαβάστε περισσότερα

Πακέτα (Packages) Φωλιασμένες ή Εσωτερικές Κλάσεις (Inner Classes) Παναγιώτης Σφέτσος, PhD

Πακέτα (Packages) Φωλιασμένες ή Εσωτερικές Κλάσεις (Inner Classes) Παναγιώτης Σφέτσος, PhD (Object Oriented Programming) Πακέτα (Packages) Φωλιασμένες ή Εσωτερικές Κλάσεις (Inner Classes) PhD http://aetos.it.teithe.gr/~sfetsos/ sfetsos@it.teithe.gr Περιεχόμενα Μαθήματος Πακέτα (Packages) Φωλιασμένες

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αντικείμενα με πίνακες. Constructors. Υλοποίηση Στοίβας

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αντικείμενα με πίνακες. Constructors. Υλοποίηση Στοίβας ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Αντικείμενα με πίνακες. Constructors. Υλοποίηση Στοίβας Στην άσκηση αυτή θα υλοποιήσετε μια κλάση Geometric η οποία διαχειρίζεται μια γεωμετρική ακολουθία ακεραίων

Διαβάστε περισσότερα

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

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Μέθοδοι ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Κλάσεις και Αντικείμενα Μέθοδοι Παράδειγμα 1 Θέλουμε ένα πρόγραμμα που να προσομοιώνει την κίνηση ενός αυτοκινήτου, το οποίο κινείται και τυπώνει τη θέση του.

Διαβάστε περισσότερα

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

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Constructors ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Κλάσεις και Αντικείμενα Constructors Μαθήματα από το lab Ένα πρόγραμμα αποτελείται από διάφορες κλάσεις και αντικείμενα αυτών των κλάσεων. Μία από τις κλάσεις

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Μέθοδοι που επιστρέφουν αντικείμενα Deep and Shallow Copies

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Μέθοδοι που επιστρέφουν αντικείμενα Deep and Shallow Copies ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Αναφορές Μέθοδοι που επιστρέφουν αντικείμενα Deep and Shallow Copies Μαθήματα από το εργαστήριο Όταν η εκφώνηση σας ζητάει να φτιάξετε μία μέθοδο που παίρνει

Διαβάστε περισσότερα

Abstract classes, Interfaces ΦΡΟΝΤΙΣΤΗΡΙΟ JAVA

Abstract classes, Interfaces ΦΡΟΝΤΙΣΤΗΡΙΟ JAVA Abstract classes, Interfaces ΦΡΟΝΤΙΣΤΗΡΙΟ JAVA Τι θα συζητήσουμε σήμερα Αφαιρέσεις στη Java Abstract μέθοδοι και abstract κλάσεις Interfaces (=διασυνδέσεις, διεπαφές) Instanceof Παραδείγματα κώδικα Αφηρημένες

Διαβάστε περισσότερα

Αντικειμενοστρεφής Προγραμματισμός Διάλεξη 4 : CLASSES

Αντικειμενοστρεφής Προγραμματισμός Διάλεξη 4 : CLASSES Αντικειμενοστρεφής Προγραμματισμός Διάλεξη 4 : CLASSES Κων. Κόκκινος Αντικειμενοστραφής Προγραμματισμός Η ιδέα του αντικειμενοστραφούς προγραμματισμού Αυτόνομες οντότητες Στιγμιότυπα οντοτήτων Παράδειγμα

Διαβάστε περισσότερα

Αντικειμενοστρέφεια. Henri Matisse, Harmony in Red, Κωστής Σαγώνας Νίκος Παπασπύρου

Αντικειμενοστρέφεια. Henri Matisse, Harmony in Red, Κωστής Σαγώνας Νίκος Παπασπύρου Αντικειμενοστρέφεια Henri Matisse, Harmony in Red, 1908 Κωστής Σαγώνας Νίκος Παπασπύρου Ορισμοί αντικειμενοστρέφειας Ποιοι είναι οι ορισμοί των παρακάτω; Αντικειμενοστρεφής

Διαβάστε περισσότερα

Αντικειμενοστρεφής Προγραμματισμός

Αντικειμενοστρεφής Προγραμματισμός Αντικειμενοστρεφής Προγραμματισμός Διδάσκουσα: Αναπλ. Καθηγήτρια Ανδριάνα Πρέντζα aprentza@unipi.gr Εργαστηριακός Συνεργάτης: Δρ. Βασιλική Κούφη vassok@unipi.gr 1 Δομημένος προγραμματισμός έναντι αντικειμενοστρεφούς

Διαβάστε περισσότερα

Εργαστήριο Java. Διδάσκουσα: Εργαστηριακοί Συνεργάτες:

Εργαστήριο Java. Διδάσκουσα: Εργαστηριακοί Συνεργάτες: Εργαστήριο Java Διδάσκουσα: Πρέντζα Ανδριάνα aprentza@unipi.gr Εργαστηριακοί Συνεργάτες: Γεωργιοπούλου Ρούλα Λύβας Χρήστος roulageorio@ssl-unipi.gr clyvas@unipi.gr Εργαστήριο 2 Βασικοί Τύποι Μεταβλητών

Διαβάστε περισσότερα

ΠΛΗΡΟΦΟΡΙΚΗ ΙI Ενότητα 1: Εισαγωγικές έννοιες

ΠΛΗΡΟΦΟΡΙΚΗ ΙI Ενότητα 1: Εισαγωγικές έννοιες ΠΛΗΡΟΦΟΡΙΚΗ ΙI Ενότητα 1: Εισαγωγικές έννοιες Μιχάλης Δρακόπουλος Σχολή Θετικών επιστημών Τμήμα Μαθηματικών ΠΛΗΡΟΦΟΡΙΚΗ ΙΙ (Java) Ενότητα 1 Αλγόριθμος: Βήμα προς βήμα διαδικασία για την επίλυση κάποιου

Διαβάστε περισσότερα

Κλάσεις. Τροποποιητές, ιασυνδέσεις, Πακέτα. Τροποποιητές ελέγχου προσπέλασης µεταβλητών και µεθόδων

Κλάσεις. Τροποποιητές, ιασυνδέσεις, Πακέτα. Τροποποιητές ελέγχου προσπέλασης µεταβλητών και µεθόδων Κλάσεις Τροποποιητές, ιασυνδέσεις, Πακέτα Τροποποιητές ελέγχου προσπέλασης µεταβλητών και µεθόδων Υπάρχουν 4τροποποιητές: default, public, private, protected. Default: εν προηγείται τροποποιητής του ονόµατος

Διαβάστε περισσότερα

Βασικά της γλώσσας JAVA

Βασικά της γλώσσας JAVA 17 η διάλεξη Π. Σταθοπούλου pstath@ece.upatras.gr ή pstath@upatras.gr Οµάδα Α (Φοιτητές µε µονό αριθµό Μητρώου ) ιδασκαλία : Παρασκευή 11πµ-13µµ ΗΛ7 Φροντιστήριο : ευτέρα 11πµ-12πµ ΗΛ4 Προηγούµενη ιάλεξη

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Υπάρχουσες κλάσεις και αντικείμενα στην Java Strings Wrapper Classes Δομές

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Υπάρχουσες κλάσεις και αντικείμενα στην Java Strings Wrapper Classes Δομές ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Υπάρχουσες κλάσεις και αντικείμενα στην Java Strings Wrapper Classes Δομές ΚΛΑΣΕΙΣ ΚΑΙ ΑΝΤΙΚΕΙΜΕΝΑ Κλάση Μια κλάση είναι μία αφηρημένη περιγραφή αντικειμένων

Διαβάστε περισσότερα

Εισαγωγή σε αντικειμενοστραφή concepts. Και λίγη C#

Εισαγωγή σε αντικειμενοστραφή concepts. Και λίγη C# Εισαγωγή σε αντικειμενοστραφή concepts Και λίγη C# Κλάσεις Κλάση: τύπος δεδομένων που αποτελεί συλλογή πεδίων, ορισμών συναρτήσεων/μεθόδων και ορισμών άλλων τύπων δεδομένων. Αντίστοιχο σκεπτικό με struct

Διαβάστε περισσότερα

I (JAVA) Ονοματεπώνυμο: Α. Μ.: Δώστε τις απαντήσεις σας ΕΔΩ: Απαντήσεις στις σελίδες των ερωτήσεων ΔΕΝ θα ληφθούν υπ όψην.

I (JAVA) Ονοματεπώνυμο: Α. Μ.: Δώστε τις απαντήσεις σας ΕΔΩ: Απαντήσεις στις σελίδες των ερωτήσεων ΔΕΝ θα ληφθούν υπ όψην. I (JAVA) Ονοματεπώνυμο: Α. Μ.: + ΦΥΛΛΟ ΑΠΑΝΤΗΣΕΩΝ Δώστε τις απαντήσεις σας ΕΔΩ: Απαντήσεις στις σελίδες των ερωτήσεων ΔΕΝ θα ληφθούν υπ όψην. + 1 ΦΥΛΛΟ ΑΠΑΝΤΗΣΕΩΝ (σελ. 2/3) 2 ΦΥΛΛΟ ΑΠΑΝΤΗΣΕΩΝ (σελ. 3/3)

Διαβάστε περισσότερα

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

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Αντικείμενα ως ορίσματα ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Αναφορές Αντικείμενα ως ορίσματα Η μνήμη του υπολογιστή Η κύρια μνήμη (main memory - RAM) του υπολογιστή κρατάει τα δεδομένα για την εκτέλεση των προγραμμάτων.

Διαβάστε περισσότερα

Αρχικοποίηση Αντικειµένων & Κλάσεων στη Java Object Instantiation & Class Initialisation Κώστας Σαΐδης saiko@di.uoa.gr http://daemon.di.uoa.gr/daemon/issue4 Μάρτιος 2004 Η Αρχή είναι το ήµισυ του Παντός

Διαβάστε περισσότερα

ΑΝΑΚΕΦΑΛΑΙΩΣΗ. Τα βασικά για την γλώσσα Java

ΑΝΑΚΕΦΑΛΑΙΩΣΗ. Τα βασικά για την γλώσσα Java JAVA, NETBEANS ΑΝΑΚΕΦΑΛΑΙΩΣΗ Τα βασικά για την γλώσσα Java Java portability Το μεγαλύτερο πλεονέκτημα της Java είναι η μεταφερσιμότητα: ο κώδικας μπορεί να τρέξει πάνω σε οποιαδήποτε πλατφόρμα. Write-Once-Run-Anywhere

Διαβάστε περισσότερα

Εαρινό. Ύλη εργαστηρίου, Ασκήσεις Java

Εαρινό. Ύλη εργαστηρίου, Ασκήσεις Java Εξάμηνο Μάθημα Τίτλος 2017 2018 Εαρινό Αντικειμενοστραφής Προγραμματισμός Ι Ύλη εργαστηρίου, Ασκήσεις Java Ημερομηνία Εργαστήριο 5 ο Α. Ύλη εργαστηρίου 5.1 Έννοιες αντικειμενοστραφούς προγραμματισμού,

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αντικείμενα ως ορίσματα

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

Διαβάστε περισσότερα

I (JAVA) Ονοματεπώνυμο: Α. Μ.: Δώστε τις απαντήσεις σας ΕΔΩ: Απαντήσεις στις σελίδες των ερωτήσεων ΔΕΝ θα ληφθούν υπ όψην.

I (JAVA) Ονοματεπώνυμο: Α. Μ.: Δώστε τις απαντήσεις σας ΕΔΩ: Απαντήσεις στις σελίδες των ερωτήσεων ΔΕΝ θα ληφθούν υπ όψην. I (JAVA) Ονοματεπώνυμο: Α. Μ.: + ΦΥΛΛΟ ΑΠΑΝΤΗΣΕΩΝ Δώστε τις απαντήσεις σας ΕΔΩ: Απαντήσεις στις σελίδες των ερωτήσεων ΔΕΝ θα ληφθούν υπ όψην. + 1 ΦΥΛΛΟ ΑΠΑΝΤΗΣΕΩΝ (σελ. 2/3) 2 ΦΥΛΛΟ ΑΠΑΝΤΗΣΕΩΝ (σελ. 3/3)

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Εισαγωγή στη Java Η εξέλιξη των γλωσσών προγραμματισμού Η εξέλιξη των γλωσσών προγραμματισμού είναι μια διαδικασία αφαίρεσης Στην αρχή ένα πρόγραμμα ήταν μια

Διαβάστε περισσότερα

Αντικειµενοστραφής Προγραµµατισµός

Αντικειµενοστραφής Προγραµµατισµός Κλάσεις Αντικειµενοστραφής Προγραµµατισµός Κλάσεις Αντικείµενα Ιεραρχία κλάσεων Κλάσεις. Ιδιότητες Συµπεριφορά Ιδιότητες (Μεταβλητές) Συµπεριφορά (Μέθοδοι) Κληρονοµικότητα Μέθοδοι επικάλυψης Η χρήση του

Διαβάστε περισσότερα

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

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Μέθοδοι ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Κλάσεις και Αντικείμενα Μέθοδοι Παράδειγμα 1 Θέλουμε ένα πρόγραμμα που να προσομοιώνει την κίνηση ενός αυτοκινήτου, το οποίο κινείται πάνω σε μία ευθεία πάντα

Διαβάστε περισσότερα

ΠΛΗΡΟΦΟΡΙΚΗ ΙΙ (JAVA) 26/2/2008

ΠΛΗΡΟΦΟΡΙΚΗ ΙΙ (JAVA) 26/2/2008 ΠΛΗΡΟΦΟΡΙΚΗ ΙΙ (JAVA) 26/2/2008 Τμήμα θεωρίας: Κάθε Τρίτη, 11πμ-2μμ, ΑΜΦ22. Διδάσκων: Ντίνος Φερεντίνος email: kpf3@cornell.edu Μάθημα: Θεωρία + προαιρετικό εργαστήριο (5-6 2ωρα εργαστήρια το εξάμηνο,

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Πολυμορφισμός Αφηρημένες κλάσεις Interfaces (διεπαφές)

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Πολυμορφισμός Αφηρημένες κλάσεις Interfaces (διεπαφές) ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Πολυμορφισμός Αφηρημένες κλάσεις Interfaces (διεπαφές) Βρείτε τα λάθη Στο πρόγραμμα στην επόμενη διαφάνεια υπάρχουν διάφορα λάθη Ποια είναι? public abstract

Διαβάστε περισσότερα

Αντικειμενοστρεφής Προγραμματισμός

Αντικειμενοστρεφής Προγραμματισμός ΑΡΙΣΤΟΤΕΛΕΙΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΘΕΣΣΑΛΟΝΙΚΗΣ ΑΝΟΙΚΤΑ ΑΚΑΔΗΜΑΙΚΑ ΜΑΘΗΜΑΤΑ Αντικειμενοστρεφής Προγραμματισμός Ενότητα 1: Εισαγωγή Γρηγόρης Τσουμάκας, Επικ. Καθηγητής Άδειες Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται

Διαβάστε περισσότερα