| Both sides previous revision
Previous revision
Next revision
|
Previous revision
|
cpp:namespace [2017/04/11 14:05] gthanos |
cpp:namespace [2021/05/06 22:52] (current) |
| ====== Namespaces ====== | ====== Χώροι Ονομάτων (Namespaces) ====== |
| |
| Προκειμένου να αποφεύγονται οι συγκρούσεις ονομάτων μεταξύ //global// μεταβλητών, κλάσεων ή συνάρτησεων η C++ ορίζει την έννοια του χώρου ονομάτων (//namespace//). Ένα //namespace// δίνει την δυνατότητα να ορίσουμε μεταβλητές, κλάσεις και μεθόδους σε ένα συγκεκριμένο χώρο ονομάτων. Η ύπαρξη πολλών //namespaces// δίνει την δυνατότητα να ορίσουμε δύο ή περισσότερες μεταβλητές, κλάσεις ή συναρτήσεις με το ίδιο όνομα που ανήκουν όμως σε διαφορετικούς χώρους ονομάτων. | Προκειμένου να αποφεύγονται οι συγκρούσεις ονομάτων μεταξύ //global// μεταβλητών, κλάσεων ή συνάρτησεων η C++ ορίζει την έννοια του χώρου ονομάτων (//namespace//). Ένας χώρος ονομάτων δίνει την δυνατότητα να ορίσουμε μεταβλητές, κλάσεις και μεθόδους μοναδικές μόνο για το συγκεκριμένο χώρο ονομάτων. Διαφορετικοί χώροι ονομάτων μπορεί να περιέχουν μεταβλητές, κλάσεις ή μεθόδους με τα ίδια ονόματα. |
| |
| Ένα //namespace// ορίζεται ως εξής: | Ένα //namespace// ορίζεται ως εξής: |
| } | } |
| </code> | </code> |
| | |
| Για παράδειγμα | Για παράδειγμα |
| <code c++> | <code c++> |
| </code> | </code> |
| |
| Η προσπέλαση/χρήση των περιεχομένων ενός namespace μπορεί να γίνει με τρεις τρόπους. | ===== Προσπέλαση των στοιχείων του namespace ===== |
| |
| === Δηλώνοντας το namespace σε κάθε κλήση των περιεχομένων του με την βοήθεια του τελεστή ''::'' === | Η προσπέλαση/χρήση των περιεχομένων ενός namespace μπορεί να γίνει με τους παρακάτω τρεις τρόπους! |
| | |
| | ==== Δηλώνοντας το namespace σε κάθε κλήση των περιεχομένων του με την βοήθεια του τελεστή :: ==== |
| | |
| | <WRAP center round tip 80%> |
| | Ο τελεστής ''::'' ονομάζεται //scope operator//. |
| | </WRAP> |
| |
| <code c++ namespace.cpp> | <code c++ namespace.cpp> |
| </code> | </code> |
| |
| === με δήλωση συγκεκριμένων ονομάτων που θα χρησιμοποιηθούν από το namespace === | ==== Mε δήλωση μόνο των ονομάτων που θα χρησιμοποιηθούν ==== |
| |
| Χρησιμοποιούμε την έκφραση ''using namespace_name::var_name'', όπως παρακάτω: | Χρησιμοποιούμε την έκφραση ''using namespace_name::var_name'', όπως παρακάτω: |
| </code> | </code> |
| |
| === με μία δήλωση των namespaces που θα χρησιμοποιηθούν === | ==== Με δήλωση του namespace από το οποίο θα χρησιμοποιηθούν συγκεκριμένα ονόματα ==== |
| Χρησιμοποιούμε την έκφραση ''using namespace namespace_name'', όπως παρακάτω: | Χρησιμοποιούμε την έκφραση ''using namespace namespace_name'', όπως παρακάτω: |
| <code c++ namespace.cpp> | <code c++ namespace.cpp> |
| </code> | </code> |
| |
| Δείτε τα σχετικά παραδείγματα που ακολουθούν. | ===== Παράδειγμα ορισμού και χρήσης μεταβλητών και μεθόδων με το ίδιο όνομα από δύο διαφορετικά namespaces ===== |
| |
| Παρακάτω δίνεται ένα παράδειγμα, όπου ορίζονται δύο διαφορετικά //namespaces// τα οποία όμως έχουν μία μεταβλητή και μία συνάρτηση με το ίδιο όνομα. Δείτε πως | Στο παράδειγμα που ακολουθεί ορίζονται δύο //namespaces// τα οποία περιέχουν μία μεταβλητή και μία συνάρτηση με κοινό όνομα. Παρατηρήστε πως διακρίνουμε τις επιμέρους μεταβλητές με χρήση του ονόματος του αντίστοιχου //namespace// πριν από την χρήση κάθε μεταβλητής ή συνάρτησης. |
| |
| <code c++ nameVisibility.cpp> | <code c++ nameVisibility.cpp> |