User Tools

Site Tools


cpp:isteams

Differences

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

Link to this comparison view

Next revision
Previous revision
cpp:isteams [2019/05/14 12:48] – created gthanoscpp:isteams [Unknown date] (current) – external edit (Unknown date) 127.0.0.1
Line 1: Line 1:
 ====== Input Streams ====== ====== Input Streams ======
  
-Όπως προαναφέρθηκε τα //streams// εισόδου χρησιμοποιούν τον τελεστη **<<** (//stream extraction operator//) για την ανάγνωση από το //stream//. H //standard// βιβλιοθήκη παρέχει συναρτήσεις υπεφόρτωσης για τους βασικούς τύπους δεδομένων, ενώ δύνεται η δυνατότητα υπερφόρτωσης για όλους τους μη βασικούς τύπους που θα χρειαστεί να κατασκευάσετε στα προγράμματα σας. Το παρακάτω παράδειγμα διαβάσματος από το πληκτρολόγιο (//stdin//) είναι ενδεικτικό.+Όπως προαναφέρθηκε τα //streams// εισόδου χρησιμοποιούν τον τελεστη %%>>%% (//stream extraction operator//) για την ανάγνωση από το //stream//. H //standard// βιβλιοθήκη παρέχει συναρτήσεις υπεφόρτωσης για τους βασικούς τύπους δεδομένων, ενώ δίνεται η δυνατότητα [[cpp:vector_overloading_binary_operators|υπερφόρτωσης]] για όλους τους μη βασικούς τύπους που θα χρειαστεί να κατασκευάσετε στα προγράμματα σας. Το παρακάτω παράδειγμα διαβάσματος από το πληκτρολόγιο (//stdin//) είναι ενδεικτικό.
  
 <code cpp istream_example.cpp> <code cpp istream_example.cpp>
 #include <iostream> #include <iostream>
-#include <cstdlib> // for exit() 
  
 using namespace std; using namespace std;
Line 32: Line 31:
 Read: 1.63 Read: 1.63
 </code> </code>
 +
 +Παρατηρήστε ότι από την πρώτη κλήση διαβάζεται ένας χαρακτήρας, ενώ από την 2η κλήση διαβάζεται το υπόλοιπο του //stream// μέχρι να συναντήσουμε κενό χαρακτήρα, χαρακτήρα //tab// ή χαρακτήρα αλλαγής γραμμής. Ο κενός χαρακτήρας, ο χαρακτήρας //tab// ή ο χαρακτήρας αλλαγής γραμμής αποτελούν διαχωριστές την πληροφορίας ανάγνωσης ενός //stream// εισόδου και αγνοούνται από το //stream//.
 +
 +====== Διαβάζοντας λέξη-λέξη ή γραμμή-γραμμή ======
 +
 +Εάν πρόκειται να διαβάσουμε ένα κείμενο, η //standard// βιβλιοθήκη μας δίνει τη δυνατότητα να διαβάσουμε το κείμενο λέξη-λέξη ως εξής:
 +
 +<code cpp input_word.cpp>
 +#include <iostream>
 +#include <cstdlib> // for exit()
 +
 +using namespace std;
 +
 +int main() {
 +  char str[256];
 +  while(!cin.eof()) {
 +    cin >> str;
 +    cout << " -> " << str << endl;
 +  }
 +}
 +</code>
 +
 +Το παραπάνω παράδειγμα για να δουλέψει με ασφάλεια θα πρέπει να είμαστε σίγουροι ότι η λέξη μέγιστου μήκους που θα διαβάσουμε θα έχει μέγεθος 255 χαρακτήρες (συν το χαρκτήρα '\0'). Εναλλακτικά μπορούμε να διαβάσουμε μία ολόκληρη γραμμή χρησιμοποιώντας τη συνάρτηση //getline// ως εξής:
 +
 +<code cpp input_line.cpp>
 +#include <iostream>
 +#include <cstdlib> // for exit()
 +
 +using namespace std;
 +
 +int main() {
 +  char str[256];
 +  while(!cin.eof()) {
 +    // Read a line of maximum size 255 bytes.
 +    cin.getline(str, 256);
 +    cout << " -> " << str <<  endl;
 +  }
 +}
 +</code>
 +
 +Σε αυτή την περίπτωση δεν είναι αναγκαίο να γνωρίζουμε ότι το μέγιστο μήκος γραμμής δεν υπερβαίνει τους 256 χαρακτήρες μαζί με τον χαρακτήρα αλλαγής γραμμής. Εάν μία γραμμή υπερβαίνει το συγκεκριμένο μέγεθος, θα διαβαστεί σε περισσότερες από μία επαναλήψεις.
 +
 +Ο παραπάνω περιορισμός δεν ισχύει εάν χρησιμοποιήσουμε την έκδοση της συνάρτησης //getline// για την κλάση ''std::string''. Σε αυτή την περίπτωση δεν απαιτείται καμία μέριμνα για το μέγεθος των εισαγόμενων συμβολοσειρών, διότι η κλάση ''std::string'' μπορεί να αποθηκεύσει συμβολοσειρές μεταβλητού μήκους και θεωρητικά άπειρου μεγέθους. Δείτε το ενδεικτικό παράδειγμα που ακολουθεί:
 +
 +<code cpp tokenize_using_std_string.cpp>
 +#include <iostream>
 +#include <cstdlib> // for exit()
 +
 +using namespace std;
 +
 +int main() {
 +  string str;
 +  while(!cin.eof()) {
 +    getline(cin, str);
 +    cout << " -> " << str <<  endl;
 +  }
 +}
 +</code>
 +
cpp/isteams.1557838136.txt.gz · Last modified: 2019/05/14 11:48 (external edit)