java:packages:dir_structure

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
java:packages:dir_structure [2015/01/23 04:58]
gthanos
java:packages:dir_structure [2016/02/26 11:15] (current)
Line 1: Line 1:
-====== ​Δομή ​των αρχείων Java ======+====== ​Μεταγλώττιση κλάσεων ​που ανήκουν σε πακέτα ​======
  
 Μέχρι τώρα είδαμε ότι κάθε κλάση στη Java αποτελεί ένα ξεχωριστό αρχείο. Για παράδειγμα η κλάση ''​myFirstClass''​ θα βρίσκεται στο αρχείο με το όνομα ''​myFirstClass.java''​. Η εισαγωγή των πακέτων στην γλώσσα Java, εκτός από την ονοματοδοσία των αρχείων καθορίζει και τον κατάλογο (directory) μέσα στο οποίο θα πρέπει να βρίσκονται. Μέχρι τώρα είδαμε ότι κάθε κλάση στη Java αποτελεί ένα ξεχωριστό αρχείο. Για παράδειγμα η κλάση ''​myFirstClass''​ θα βρίσκεται στο αρχείο με το όνομα ''​myFirstClass.java''​. Η εισαγωγή των πακέτων στην γλώσσα Java, εκτός από την ονοματοδοσία των αρχείων καθορίζει και τον κατάλογο (directory) μέσα στο οποίο θα πρέπει να βρίσκονται.
  
-Ως παράδειγμα,​ θα θεωρήσουμε ξανά την κλάση Test του homework1 του ​τρέχοντος ​μαθήματος ​(CE325). Με βάση τα παραπάνω διαμορφώνεται το πακέτο με όνομα ''​gr.uth.inf.ce325.homework1''​ μέσα στο οποίο βρίσκεται η κλάση ''​Test''​.+Ως παράδειγμα,​ θα θεωρήσουμε ξανά την κλάση Test του homework1 του μαθήματος CE325. Με βάση τα παραπάνω διαμορφώνεται το πακέτο με όνομα ''​ce325.homework1''​ μέσα στο οποίο βρίσκεται η κλάση ''​Test''​. ​Η ενδεικτική κλάση **Test** δίνεται παρακάτω
  
-Ας θεωρήσουμε επίσης ότι το homework1 ​είναι ένα ξεχωριστό project που ​βρίσκεται μέσα στον κατάλογο ''​CE325/​Homework1/'' ​(ο οποίος με την σειρά του βρίσκεται ​σε ένα τυχαίο μονοπάτι του filesystem). Ιδανικά θα θέλαμε να διαχωρίσουμε τα αρχεία πηγαίου κώδικα **.java** από τα εκτελέσιμα αρχεια **.class**. Για τον λόγο αυτό δημιουργούμε δύο υποκαταλόγους ''​src''​ για τον πηγαίο κώδικα και ''​build''​ για τα εκτελέσιμα αρχεία. Τελικά,​ έχουμε τους καταλόγους ​+<code java Test.java>​ 
 +package ce325.homework1;​ 
 +public class Test { 
 +  String test;   
 +  public Test(String s) { test = s; } 
 +  public String toString() { return test; } 
 +
 +</​code>​ 
 + 
 +Ας θεωρήσουμε επίσης ότι ​όλα ​τα αρχεία ​της συγκεκριμένης εργασίας ​βρίσκονται μέσα στον κατάλογο ''​project1/''​σε ένα τυχαίο μονοπάτι του filesystem. Ιδανικά θα θέλαμε να διαχωρίσουμε τα αρχεία πηγαίου κώδικα **.java** από τα εκτελέσιμα αρχεια **.class**. Για τον λόγο αυτό δημιουργούμε δύο υποκαταλόγους ​ 
 +  - ''​src''​ για τον πηγαίο κώδικα και ​ 
 +  - ''​build''​ για τα μεταγλωττισμένα αρχεία. ​ 
 + 
 +Τελικά,​ έχουμε τους καταλόγους ​
  
 <​code>​ <​code>​
-CE325/​Homework1/src +project1/src 
-CE325/​Homework1/build+project1/build
 </​code>​ </​code>​
  
-Προκειμένου να μεταγλωττίσουμε την κλάση ''​gr.uth.inf.ce325.homework1.Test'',​ αυτή θα πρέπει να βρίσκεται στον κατάλογο ''​gr/uth/inf/ce325/​homework1/''​ μέσα στον φάκελο ''​src'',​ δηλαδή ​συνολικά θα έχουμε.+Προκειμένου να μεταγλωττίσουμε την κλάση ''​ce325.homework1.Test'',​ αυτή θα πρέπει να βρίσκεται στον κατάλογο ''​ce325/​homework1/''​ μέσα στον φάκελο ''​src'',​ δηλαδή ​τελικά ​η κλάση **Test.java** ​θα βρίσκεται στον κατάλογο
  
 <​code>​ <​code>​
-CE325/​Homework1/src/gr/uth/inf/​ce325/​homework1/​Test.java+project1/​src/​ce325/​homework1/​Test.java
 </​code>​ </​code>​
  
-Η παραπάνω κλάση μεταγλωττίζεται με μία δήλωση της μορφής+Υποθέτοντας ότι μεταβαίνουμε μέσα στον κατάλογο project1, η παραπάνω κλάση μεταγλωττίζεται με μία δήλωση της μορφής
  
 <​code>​ <​code>​
-cd CE325/​Homework1+cd project1
-javac -d ./build/ src/gr/uth/inf/​ce325/​homework1/​Test.java ​+javac -d ./build/ src/​ce325/​homework1/​Test.java ​
 </​code>​ </​code>​
  
-To directive ''​-d ./​build/'' ​δείχνει που θέλουμε να τοποθετήσουμε τελικά τα εκτελέσιμα αρχεία ''​*.class''​. +<WRAP tip 80% center round> 
-Η τελική θέση του εκτελέσιμου **Test.class** είναι ''​build/​gr/uth/inf/​ce325/​homework1/​Test.class''​. O java  compiler φτιάχνει την δομή καταλόγου των αρχείων **.class** αυτόματα ​εν χρειάζεται να το κάνετε εσείςμε βάση την δομή των αρχείων **.java**.+To directive ''​-d ./​build/'' ​χρησιμοποιείται για ​να δηλώσουμε πού θέλουμε να τοποθετήσουμε τελικά τα εκτελέσιμα αρχεία ''​*.class''​. Η τελική θέση του εκτελέσιμου **Test.class** είναι ​ ​στον κατάλογο ​''​project1/build''​. Επειδή το μεταγλωττισμένο αρχείο θα πρέπει να βρίσκεται εσωτερικά στον κατάλογο ''​ce325/homework1/''​ τελικά καταλήγουμε το πλήρες path του μεταγλωττισμένου αρχείου να είναι ''​project1/build/​ce325/​homework1/​Test.class''​. O java  compiler φτιάχνει την δομή καταλόγου των αρχείων **.class** ​__αυτόματα ​με βάση το πακέτο στο οποίο ανήκουν__. 
 +</​WRAP>​ 
 + 
 +ροηγούμενο: [[ :​java:​packages:​using | Χρήση (μεταγλωττισμένων) κλάσεων από άλλες κλάσεις ]] | [[ :toc | Περιεχόμενα ]] | Επόμενο: [[ :​java:​jar_files | Αρχεία Java Archive (JAR) ]] |
java/packages/dir_structure.1421989129.txt.gz · Last modified: 2016/02/26 11:15 (external edit)