05β Η ιδεατή μηχανή της Java

Σχετικά έγγραφα
Η ιδεατή μηχανή της Java

03 Η ιδεατή μηχανή της Java

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

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

1. Ξεκινώντας. 1.1 Τι είναι η Java. PDF created with FinePrint pdffactory Pro trial version

08 Η γλώσσα UML I. Τεχνολογία Λογισμικού. Σχολή Hλεκτρολόγων Mηχανικών & Mηχανικών Yπολογιστών Εθνικό Μετσόβιο Πολυτεχνείο. Χειμερινό εξάμηνο

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

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

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

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

Είναι μια αλληλουχία κατάλληλων οδηγιών(εντολών) που εκτελεί ο υπολογιστής για την επίλυση ενός προβλήματος.


Σχεδίαση Γλωσσών Προγραμματισμού. Εαρινό Εξάμηνο Lec03 18/02/2019

Εργαλεία του JDK. Β.1 Εργαλεία του JDK. Β.2 Μεταγλωττιστής javac. Τα πιο βασικά εργαλεία του JDK είναι τα παρακάτω.

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

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

Τι σημαίνει; n Για την αποδοτική δέσμευση δομών δεδομένων μη. n Για την αποφυγή «διαρροών μνήμης» (memory leaks).

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

ΕΠΛ 233: Αντικειμενοστρεφής Προγραμματισμός (Object-oriented programming)

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

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

Λειτουργικά Συστήματα. Εισαγωγή

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

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

03 Τεχνική διαχείριση έργων λογισμικού

Λειτουργικά Συστήματα (Λ/Σ)

ProcSim οδηγίες χρήσης.

11β Δομικά πρότυπα σχεδίασης

Διεργασίες (μοντέλο μνήμης & εκτέλεσης) Προγραμματισμός II 1

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

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

ΚΕΦΑΛΑΙΟ 2: Τύποι δεδομένων και εμφάνιση στοιχείων...33

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

Επιτεύγµατα των Λ.Σ.

02α Διαχείριση Έργων Λογισμικού

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

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

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

Digital Academy. Εισαγωγή στην ανάπτυξη Android Εφαρμογών

Java sessions. Part 1 - Βασικά έννοιες - μέθοδοι

ΕΙΔΗ,ΤΕΧΝΙΚΕΣ ΚΑΙ ΠΕΡΙΒΑΛΛΟΝΤΑ ΠΡΟΓΡΑΜΜΑΤΙ- ΣΜΟΥ

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

ΔΕΙΚΤΕΣ ΚΑΙ ΔΙΕΥΘΥΝΣΕΙΣ

Περιγραφή Μαθήματος ΠΕΡΙΓΡΑΦΗ ΜΑΘΗΜΑΤΟΣ. Γεώργιος Παπαϊωάννου ( )

Τεχνολογία Λογισμικού

ProcSim οδηγίες χρήσης.

Βρίγκας Μιχαήλ Α.Μ.744 Μπράχος Χ. Ευάγγελος Α.Μ.795

ΕΠΛ233 Βασικά στοιχεία προγραµµατισµού στη JAVA

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

Πανεπιστήμιο Μακεδονίας Τμήμα Εφαρμοσμένης Πληροφορικής. Mic-1 MMV. Προσομοιωτής Αρχιτεκτονικής H/Y

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

ProcSim οδηγίες χρήσης.

ΛΕΙΤΟΥΡΓΙΚΑ ΣΥΣΤΗΜΑΤΑ ΔΙΑΧΕΙΡΙΣΗ ΜΝΗΜΗΣ

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

Δημιουργία μιας εφαρμογής Java με το NetBeans

Εισαγωγή στην Πληροφορική

Τεχνολογία Λογισμικού

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

! Ο καλός προγραμματισμός επιβάλλει την αποδοτική χρήση. ! Είναι σημαντικό να καταλαβαίνουμε τις διαδικασίες

06 Αντικειμενοστρεφής ανάλυση και σχεδιασμός

ΕΞΕΤΑΣΤΕΑ ΥΛΗ (SYLLABUS) ADVANCED αντικειμενοστραφής προγραμματισμός ΕΚΔΟΣΗ 1.0. Σόλωνος 108,Τηλ Φαξ

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

09 Η γλώσσα UML II. Τεχνολογία Λογισμικού. Σχολή Hλεκτρολόγων Mηχανικών & Mηχανικών Yπολογιστών Εθνικό Μετσόβιο Πολυτεχνείο. Χειμερινό εξάμηνο

ΜΥΥ- 402 Αρχιτεκτονική Υπολογιστών Μεταγλώτιση, σύνδεση

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

07 Διαχείριση έργων λογισμικού ΙΙ

Υποστηρικτικό υλικό Σημειώσεις

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

Παράλληλη Επεξεργασία

Εξοικείωση με τα Εργαλεία για το μάθημα Τεχνολογίες Εφαρμογών Διαδικτύου. Χειμερινό

10α Έλεγχος και επαλήθευση λογισμικού

ΚΕΦΑΛΑΙΟ 1. Εισαγωγή στην Python. 1.1 Εισαγωγή

Διεργασίες (μοντέλο μνήμης & εκτέλεσης) Προγραμματισμός II 1

<<ΔΗΜΗΤΡΗΣ ΜΑΝΩΛΗΣ ΦΥΣΙΚΟΣ ΜCs>> 1

Αντικειμενοστραφής Προγραμματισμός I (5 ο εξ) Διάλεξη #1 η : Εισαγωγή: Λογισμικό, Γλώσσες Προγραμματισμού, Java

Αναπτύσσοντας developer tools στην Αpple. Αργύριος Κυρτζίδης Προπτυχιακός φοιτητής ΗΜΜΥ

ΚΑΛΑΝΙΔΟΥ ΓΑΛΗΝΗ ΚΑΝΑΚΟΥΣΑΚΗ ΜΑΡΙΑ

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

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

11α Κατασκευαστικά πρότυπα σχεδίασης

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

ProcSim οδηγίες χρήσης.

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

Εικονικές Μηχανές, ιερµηνείς και υναµική ιαχείριση Μνήµης

Εισαγωγή στο πρόγραμμα DrJava 1

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

1. ΑΡΧΕΣ ΛΕΙΤΟΥΡΓΙΚΩΝ ΣΥΣΤΗΜΑΤΩΝ

Τεχνολογία Διοίκησης Επιχειρησιακών Διαδικασιών

Ε-85: Ειδικά Θέµατα Λογισµικού

Η-Υ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ. Εργαστήριο 1 Εισαγωγή στη C. Σοφία Μπαλτζή s.mpaltzi@di.uoa.gr

HelloApplet. Παύλος Εφραιμίδης Java Applets 1

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

Φροντιστήριο. Παραγωγή τελικού κώδικα. Παραγωγή τελικού κώδικα

ΛΕΙΤΟΥΡΓΙΚΑ ΣΥΣΤΗΜΑΤΑ ΕΙΣΑΓΩΓΗ

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

Εισαγωγή. Διαλέξεις στο μάθημα: Μεταφραστές Γιώργος Μανής

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

Ανάπτυξη διαδικτυακής εφαρμογής σε περιβάλλον κινητών συσκευών με λειτουργικό σύστημα Android

ΕΠΛ233 ΠΛΗΡΟΦΟΡΙΑ ΤΥΠΟΥ. Type Information. Μ. Δικαιάκος

Κεφάλαιο 7 : Είδη, Τεχνικές, και Περιβάλλοντα Προγραµµατισµού

Transcript:

05β Η ιδεατή μηχανή της Java Τεχνολογία Λογισμικού Σχολή Hλεκτρολόγων Mηχανικών & Mηχανικών Yπολογιστών Εθνικό Μετσόβιο Πολυτεχνείο Χειμερινό εξάμηνο 2017 18 Δρ. Κώστας Σαΐδης saiko@di.uoa.gr

Περιεχόμενα Η πλατφόρμα της Java γενικά Εισαγωγή στο Java Virtual Machine JVM 2

Η πλατφόρμα της Java Java Runtime Environment JRE Java virtual machine Java class library Java Development Kit JDK JRE + Eργαλεία ανάπτυξης κώδικα σε γλώσσα Java javac java compiler javadoc παραγωγή HTML τεκμηρίωσης από τον πηγαίο κώδικα jdb debugger κ.ά. 3

Java Class Library Τα βασικά APIs I/O & Networking Files, Sockets, κ.ά Threads Collections & Streams v8 Security & Encryption SQL Databases XML GUI swing 4

Ανάπτυξη της Java Java Community Process JCP Java Specification Requests JSRs Reference implementations of APIs Open JDK GNU GPL v2 Reference implementation of Java JVM + Tools + Class Library 5

Σύντομη εισαγωγή στο JVM 6

Βασικά χαρακτηριστικά Διαλειτουργικότητα Portability Write once, run everywhere Αυτόματη διαχείριση μνήμης Garbage collection Υποστήριξη για πολλαπλά νήματα threads Just In Time Μεταγλώττιση Γρήγορο, στιβαρό, αξιόπιστο και διεθνώς διαδεδομένο περιβάλλον εκτέλεσης σε servers, desktops, κινητά, άλλες συσκευές 7

Η δομή του JVM By Michelle Ridomi Own work, CC BY SA 4.0, https://commons.wikimedia.org/w/index.php?curid=35963523 8

Η δομή του JVM Method area: αποθήκευση των κλάσεων και των σχετικών τους πληροφοριών μέθοδοι, πεδία, υπερ κλάσεις, κτλ.. Heap area: αποθήκευση όλων των αντικειμένων / στιγμιοτύπων. Language stacks: κάθε thread έχει τη δική του στοίβα, όπου αποθηκεύονται τοπικές μεταβλητές, ενδιάμεσα αποτελέσματα, κτλ σε μορφή stack frames. PC registers: Program counter register που περιέχει τη διεύθυνση του υπό εκτέλεση bytecode instruction. Native method stacks: αποθηκεύονται όλες οι native μέθοδοι της εφαρμογής. 9

Class Loader Μηχανισμός που επιτρέπει την παραμετροποιήσιμη προγραμματιστικά φόρτωση των κλάσεων στο JVM.class files, bytecode Οι class loaders είναι "κανονικά" Java αντικείμενα τύπου java.lang.classloader Μια εφαρμογή Java μπορεί να έχει πολλαπλούς class loaders 10

Ορισμός κλάσεων java.lang.class Κατά την εκτέλεση του προγράμματος, οι κλάσεις αναπαρίστανται από "κανονικά" Java αντικείμενα reflection Προσοχή Για την ίδια κλάση, όταν αυτή φορτώνεται από διαφορετικούς class loaders, παράγονται διαφορετικά Class αντικείμενα. 11

Βήματα 1. Χρήση του class loader για φόρτωση της κλάσης από το δίσκο, το δίκτυο ή από κάπου αλλού π.χ. δυναμική επιτόπου παραγωγή της, on the fly 2. Σύνδεση της κλάσης linking Επιβεβαίωση bytecode Εντοπισμός και αρχικοποίηση εξαρτήσεων 3. Αρχικοποίηση της κλάσης static πεδία, blocks και μέθοδοι 12

Αρχικοποίηση κλάσεων Οκνηρή / lazy ακριβώς πριν την πρώτη χρήση τους. Που είναι πότε; Πριν στιγμιοτυπιθεί ένα αντικείμενο της κλάσης. Πριν κληθεί μια static μέθοδος της κλάσης. Πριν προσπελαστεί ένα static πεδίο της κλάσης είτε για ανάγνωση, είτε για εγγραφή της τιμής του Η αρχικοποίηση μιας κλάσης προϋποθέτει την αρχικοποίηση της υπερ κλάσης της super class. Η αρχικοποίηση μιας κλάσης γίνεται μόνο μία φορά ανά class loader. 13

Διάφανη χρήση των class loaders από το JVM To JVM διαθέτει έναν Bootstap class loader για τη φόρτωση των class libraries. Το JVM χρησιμοποιεί έναν γενικής χρήσης class loader για την φόρτωση των κλάσεων της εφαρμογής συνήθως τύπου java.net.urlclassloader. Δεν είναι σύνηθες να απαιτείται η συγγραφή class loader από τον προγραμματιστή. 14

Η μηχανή εκτέλεσης του JVM Εκτέλεση του bytecode. Διερμηνέας / interpreter. Εκτέλεση γραμμή γραμμή. Just in time μεταγλωττιστής / compiler. Μεταγλώττιση του bytecode σε native κώδικα ανάλογα με τη χρήση. Δραστική βελτίωση στην απόδοση. Garbage collector. Εκτελείται στο παρασκήνιο και απελευθερώνει/διαχειρίζεται τη μνήμη της εφαρμογής heap. 15

To JVM Heap Όλα τα αντικείμενα αποθηκεύονται στο Heap. 16

Όλα μα όλα τα αντικείμενα java.lang.outofmemoryerror συνήθως λόγω μη διαθέσιμου ελεύθερου χώρου στο Heap Ειδικές παράμετροι στην εκκίνηση του JVM Ελάχιστο heap size: Xms512M Μέγιστο heap size: Xmx2048M 17

Το JVM διαχειρίζεται το Heap Με διάφανο για τον προγραμματιστή τρόπο. Αυτόματη δέσμευση και αποδεύσμευση μνήμης pointers. Αυτόματοι έλεγχοι εύρους buffer overflows & underflows. Garbage collection: αυτόματη απελευθέρωση μνήμης των αντικειμένων που δε χρησιμοποιούνται πλέον από το πρόγραμμα. 18

Garbage collection Θεμελιώδης έννοια: reachability of references/objects. Διάφοροι αλγόριθμοι: καταμέτρησης αναφορών, σημείωσης και εκκαθάρισης, σειριακοί, παράλληλοι, με ολική παύση του προγράμματος stop the world, με συμπύκνωση της θρυμματισμένης μνήμης, με έμφαση στην ταχύτητα δέσμευσης/αποδέσμευσης. 19

Στα σύγχρονα JVM Generational Garbage Collector 20

Βασική ιδέα Κατηγοριοποίηση των αντικειμένων με βάση τη "γενιά" τους. Τα περισσότερα αντικείμενα "πεθαίνουν νέα". Κάποια, λίγα, αντικείμενα "ζουν" για πολύ μεγάλα διαστήματα. Σπάνια τα "παλιά" αντικείμενα αναφέρονται σε "νέα". Μετακίνησή των αντικειμένων από τις νεότερες στις παλαιότερες γενιές ανάλογα με το πόσες "συλλογές/ εκτελέσεις" του GC έχουν καταφέρει να επιβιώσουν. Ταχύτερη συλλογή χώρου από τις νέες γενιές: μικρότερες παύσεις. 21

Garbage First Garbage Collector Java 9 22

Εκτέλεση του JVM $ java cp CLASSPATH package.of.mainclass $ java jar app.jar Classpath: λίστα από τοποθεσίες που περιέχουν.class αρχεία συνήθως φάκελοι ή jar αρχεία MainClass: το πλήρες όνομα της κλάσης που περιέχει την main μέθοδο Jar file: αρχείο zip με κλάσεις.class και λοιπά στοιχεία λειτουργίας manifests, resources, κ.ά 23

Έννοιες Language abstractions Classes, Interfaces, Types Packages = namespaces of the above Modules Java 9, = strongly encapsulated namespaces of packages Application abstractions Components logical Layers logical Tiers physical Subsystems logical or physical 24

Java packages και δομή καταλόγων package com.foo.bar; class Main {... } src com foo bar Main.java Θα επανέλθουμε σε επόμενη διάλεξη 25

Java 9 Modules module com.foo.bar { requires com.foo.baz; exports com.foo.bar.alpha; exports com.foo.bar.beta; } Δεν θα μας απασχολήσουν στο μάθημα 26