cpp:function_templates
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
cpp:function_templates [2019/05/02 14:10] – [Templates Συναρτήσεων] gthanos | cpp:function_templates [Unknown date] (current) – external edit (Unknown date) 127.0.0.1 | ||
---|---|---|---|
Line 26: | Line 26: | ||
Ας προσπαθήσουμε να χρησιμοποιήσουμε την παραπάνω συνάρτηση. | Ας προσπαθήσουμε να χρησιμοποιήσουμε την παραπάνω συνάρτηση. | ||
- | <code cpp maximum1.cpp> | + | <code cpp find_max1.cpp> |
template < | template < | ||
T& maximum(T& | T& maximum(T& | ||
Line 47: | Line 47: | ||
<WRAP tip 80% center round> | <WRAP tip 80% center round> | ||
Μπορείτε να παραλείψετε τον τύπο των παραμέτρων κατά την κλήση της συνάρτησης **maximum** ως εξής: | Μπορείτε να παραλείψετε τον τύπο των παραμέτρων κατά την κλήση της συνάρτησης **maximum** ως εξής: | ||
- | <code cpp maximum1.cpp> | + | <code cpp find_max1.cpp> |
template < | template < | ||
T& maximum(T& | T& maximum(T& | ||
Line 64: | Line 64: | ||
</ | </ | ||
- | ===== Templates | + | ===== Templates |
- | Ας υποθέσουμε ότι θέλουμε να κάνουμε χρήση της παραπάνω συνάρτηση **maximum** προκειμένου να βρούμε το μέγιστο μεταξύ δύο φοιτητών. Η κλάση του φοιτητή δίνεται παρακάτω: | + | Ας υποθέσουμε ότι θέλουμε να κάνουμε χρήση της παραπάνω συνάρτηση **maximum** προκειμένου να βρούμε το μέγιστο μεταξύ δύο φοιτητών. Η κλάση |
- | <code cpp Student.hpp> | + | Εφόσον προσθέσουμε την παραπάνω συνάρτηση υπεφόρτωσης του τελεστή %%>%% το πρόγραμμα εκτυπώνει τα εξής: |
+ | <code cpp find_max2.cpp> | ||
+ | #include < | ||
+ | #include "Student.hpp" | ||
+ | using namespace std; | ||
- | #include<cstring> | + | template |
+ | T& maximum(T& | ||
- | class Student { | + | int main() { |
- | char *name; | + | |
- | | + | |
- | + | ||
- | public: | + | |
- | Student(const char *name, int aem); | + | |
- | Student(); | + | |
- | ~Student(); | + | |
- | char *getName() const; | + | |
- | int getAEM() const; | + | |
- | friend std:: | + | |
- | }; | + | |
- | Student:: | + | cout << "max(' |
- | this-> | + | |
- | strcpy(this-> | + | |
- | this-> | + | |
} | } | ||
+ | </ | ||
- | Student:: | + | ===== Templates συναρτήσεων με αριθμητικές παραμέτρους ===== |
- | this-> | + | |
- | this-> | + | |
- | } | + | |
- | Student::~Student() { | + | Ας υποθέσουμε τώρα ότι θέλουμε να βρούμε το μέγιστο μεταξύ περισσότερων των δύο αριθμητικών τιμών οι οποίες έχουν αποθηκευτεί σε ένα πίνακα. Σε αυτή την περίπτωση η συνάρτηση **maximum** θα μπορούσε να γραφεί ως εξής: |
- | if(name != nullptr) | + | |
- | delete []name; | + | |
- | } | + | |
- | char* Student:: | + | <code cpp> |
- | | + | template < |
- | } | + | T& maximum(T a[]) { |
- | + | | |
- | int Student:: | + | for(int i=1; i<size; i++) |
- | | + | if(a[i]>max) |
- | } | + | max = a[i]; |
- | + | return | |
- | std:: | + | |
- | out << st.name << " " << st.aem; | + | |
- | return | + | |
} | } | ||
</ | </ | ||
- | O κώδικας που κάνει χρήση της παραπάνω κλάσης είναι ο εξής: | + | Παρατηρήστε ότι |
- | + | ||
- | <code cpp maximum2.cpp> | + | |
- | template < | + | |
- | T& maximum(T& | + | |
+ | Ο κώδικας χρήσης της παραπάνω συνάρτησης θα μπορούσε να είναι ο εξής: | ||
+ | <code cpp find_max3.cpp> | ||
#include < | #include < | ||
using namespace std; | using namespace std; | ||
Line 126: | Line 108: | ||
#include " | #include " | ||
- | int main() { | + | template < |
- | Student george(" | + | |
- | cout << " | + | |
- | } | + | |
- | </ | + | |
- | + | ||
- | Εάν προσπαθήσουμε να μεταγλωττίσουμε, | + | |
- | + | ||
- | <code cpp> | + | |
- | // σύγκριση δύο μαθητών με βάση το ΑΕΜ τους | + | |
- | bool Student:: | + | |
- | if(aem < st.aem) | + | |
- | return true; | + | |
- | return false; | + | |
- | } | + | |
- | </ | + | |
- | + | ||
- | Εφόσον προσθέσουμε την παραπάνω συνάρτηση υπεφόρτωσης του τελεστή **> | + | |
- | < | + | |
- | max(' | + | |
- | </ | + | |
- | + | ||
- | ===== Templates συναρτήσεων με αριθμητικές παραμέτρους ===== | + | |
- | + | ||
- | Ας υποθέσουμε τώρα ότι θέλουμε να βρούμε το μέγιστο μεταξύ περισσότερων των δύο αριθμητικών τιμών οι οποίες έχουν αποθηκευτεί σε ένα πίνακα. Σε αυτή την περίπτωση η συνάρτηση **maximum** θα μπορούσε να γραφεί ως εξής: | + | |
- | + | ||
- | template < | + | |
T& maximum(T a[]) { | T& maximum(T a[]) { | ||
T& max = a[0]; | T& max = a[0]; | ||
Line 160: | Line 116: | ||
return max; | return max; | ||
} | } | ||
+ | |||
+ | int main() { | ||
+ | Student george(" | ||
+ | Student students[] = { george, kate, mary }; | ||
+ | cout << " | ||
+ | } | ||
+ | </ | ||
cpp/function_templates.1556806230.txt.gz · Last modified: 2019/05/02 13:10 (external edit)